加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

为什么内存使用量超过Linux中的物理RAM?

发布时间:2020-12-13 19:50:39 所属栏目:Linux 来源:网络整理
导读:我正在研究一个具有512MB RAM和足够交换内存的嵌入式系统来支持该应用程序.从内核中,我将内核cmd参数的RAM大小限制为130MB.并使用swapoff -a禁用交换.我还禁用了内核过度使用,因此应用程序可以单独在物理内存中运行.我验证了/ proc / cmdline和/ proc / memi
我正在研究一个具有512MB RAM和足够交换内存的嵌入式系统来支持该应用程序.从内核中,我将内核cmd参数的RAM大小限制为130MB.并使用swapoff -a禁用交换.我还禁用了内核过度使用,因此应用程序可以单独在物理内存中运行.我验证了/ proc / cmdline和/ proc / meminfo的更改.现在,当我运行应用程序并检查顶部值时,我的应用程序的VSZ是177m,这超过了实际的内存!这怎么可能?这个记忆是从哪里来的?

解决方法

VSZ是进程使用的虚拟内存大小.这是正常的,它高于你的物理内存的大小,因为这是其中一个主要的想法.您应该查看Resident size(RSS),它是进程使用的实际物理内存.

看看这个例子:

我有一个运行的nginx进程:

ps -o rss,vsz,cmd ax | grep -i nginx | head -n1
  956  31248 nginx: master process /usr/sbin/nginx -c /etc/nginx/nginx.conf

rss - 956 kB
vsz - 31248 kB

因此,这意味着此过程使用956kB的物理内存和31MB的虚拟内存.

与您一样,禁用交换(swapoff -a)不会禁用虚拟内存.

在这里阅读虚拟内存:
Virtual memory

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读