为什么 ps 命令中的内存 (rss) 与 top 命令中看到的内存不同?

为什么 ps 命令中的内存 (rss) 与 top 命令中看到的内存不同?

在 MacOS Catalina 上,当检查进程的内存使用情况时,我发现该ps命令显示的 RSS 值与顶部显示的内存使用情况不同:

$> ps e -o command,vsize,rss,%mem|grep "myapplication"|head -n 1
myapplication  4594896  51364  0.3

RSS -> 51364

top
PID    COMMAND       %CPU TIME    #TH             #WQ  #PORT MEM    
48106  myapplication 115.7        09:06.12 69/1   1    101   37M+

内存 -> 37M

为什么会有这样的差异?

更新:

IntelliJ 流程的另一个示例:

top -pid 357
PID  COMMAND      %CPU TIME     #TH   #WQ  #POR MEM    PURG CMPRS  PGRP PPID STATE    BOOSTS        %CPU_ME %CPU_OTHRS UID       FAULTS    COW   MSGSENT  MSGRECV  SYSBSD
357  idea         2.6  03:16:46 112   1    925  4906M  0B   1583M  357  1    sleeping  0[2884]      0.00000 0.00000    281451937 28337096  54627 8404446+ 2733245+ 156093159+

热门节目4906M

ps aux
USER               PID  %CPU %MEM        VSZ    RSS   TT  STAT STARTED      TIME COMMAND

xxxxxxx            357   3.6 14.5 180050484 2430728   ??  S     1:44PM 196:48.70 /Applications/IntelliJ IDEA.app/Contents/MacOS/idea -psn_0_73746

ps显示RSS2430728(知识库)

答案1

最可能的原因是 ps 显示常驻内存,而 top 显示总内存或虚拟内存(例如包括换出和共享)。

对此有很多疑问,包括https://stackoverflow.com/questions/7880784/what-is-rss-and-vsz-in-linux-memory-management但这就是为什么它们在这里具有不同的值。

相关内容