我的主机上运行了很多进程实例,每个进程看起来都消耗了大量内存。
过程中的ps aux给我以下信息
blah1 18634 0.0 0.4 131852 31188 pts/15 Ssl+ 00:27 0:00 myPgm
blah2 18859 0.0 0.3 131292 30656 pts/32 Sl+ 01:17 0:00 myPgm
blah3 19813 0.0 0.4 131960 31220 pts/44 Ssl+ 01:17 0:00 myPgm
blah4 20228 0.1 0.3 131728 31036 pts/54 Ssl+ 01:41 0:00 myPgm
blah5 20238 0.0 0.3 131688 30932 pts/20 Sl+ Nov15 0:00 myPgm
blah6 21181 0.0 0.3 131304 30632 pts/25 Sl+ Nov15 0:00 myPgm
blah7 21278 0.0 0.3 131824 31096 pts/61 Ssl+ Nov15 0:00 myPgm
blah8 21821 0.0 0.3 131444 30808 pts/7 Sl+ 00:54 0:00 myPgm
所以VSZ总是大约130 MB,RSS大约30 MB。进程的pmap具有以下数据: 对于18634:
mapped: 131852K writeable/private: 59692K shared: 28K
对于21181:
mapped: 131304K writeable/private: 59144K shared: 28K
以及其他过程的类似值。主机有7GB的物理内存。有时我在主机上运行大约700到800个相同进程的实例。我试图了解每个进程在实际中消耗了多少内存。如果我将“可写/私有”作为每个进程中的实际内存使用量,那么每个进程58MB将导致45 GB(对于800进程)这是疯狂的。任何人都可以解释我是否做错了怎么办呢?
同样免费-k给出
total used free shared buffers cached
Mem: 7782580 4802104 2980476 0 380192 1931708
-/+ buffers/cache: 2490204 5292376
Swap: 1048568 32 1048536
看起来没有使用多少交换,现在每个进程的内存来自哪里?感谢。
答案 0 :(得分:1)
你不知道VSZ是什么。你认为你知道,但证据表明不然,因此你需要找出它是什么。
VZS是虚拟内存大小,这是进程所需的所有内存,包括共享内存。这就是为什么你不能只求和(VSZ)并且期望得到的内存+交换的物理量少。
pmap中的映射内存可能对应于VSZ,而且可写/私有,我想是某些进程共享的内存,其中每个进程都有对该内存的写访问权限(如他们的父进程左右)。
要理解这一点,您需要了解内存分配和访问的工作原理,这很困难。 http://emilics.com/blog/article/mconsumption.html这篇文章似乎在一些细节上解释了它(但我只是粗略地阅读)