在 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但这就是为什么它们在这里具有不同的值。