为什么linux下用top统计出来的进程内存不准确

为什么linux下用top统计出来的进程内存不准确,第1张

进程所占的内存在是虚拟内存。 *** 作系统将物理内存做虚拟化后,阁下看到的都是虚拟内存。同理,进程看到的,识别到的也是虚拟内存。不过他们的基础和物理基础是无力内存。这样你拿虚拟的内存去匹配无力内存当然是有出入的。

大概意思就是,linux在内存管理上,倾向于尽量多地使用内存来提高读写的性能,因此你程序运行结束后cached的内容并不会马上被释放,方便下一次读取。

free命令显示的内容,第一行的数据是以系统视角看的,第二行的数据是以应用程序的视角看的。

第一行的used一项,其数据不单包含程序使用的内存,还包含buffers跟cached的内存,因此看上去可用的内存很少。

第二行的数据,分别是used-buffers-cached,跟free+buffers+cached,算了一下程序总的内存使用率是(total - free - buffers - cached) / total = 0.038 左右,因此top显示一列0.0也没什么问题。

作者:陈颖聪

链接:https://www.zhihu.com/question/49823402/answer/117980611

来源:知乎

著作权归作者所有,转载请联系作者获得授权。

这是Linux内存管理机制。

无论物理内存有多大,Linux 都将其充份利用,将一些程序调用过的硬盘数据读入内存,利用内存读写的高速特性来提高Linux系统的数据访问性能。而Windows是只在需要内存时,才为应用程序分配内存,并不能充分利用大容量的内存空间。换句话说,每增加一些物理内存,Linux都将能充分利用起来,发挥了硬件投资带来的好处,而Windows只将其做为摆设,即使增加8GB甚至更大。

Linux的这一特性,主要是利用空闲的物理内存,划分出一部份空间,做为cache、buffers ,以此提高数据访问性能。

页高速缓存(cache)是Linux内核实现的一种主要磁盘缓存。它主要用来减少对磁盘的I/O *** 作。具体地讲,是通过把磁盘中的数据缓存到物理内存中,把对磁盘的访问变为对物理 内存的访问。

磁盘高速缓存的价值在于两个方面:第一,访问磁盘的速度要远远低于访问内存的速度,因此,从内存访问数据比从磁盘访问速度更快。第二,数据一旦被访问,就很有可能在短期内再次被访问到。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/7236744.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-03
下一篇2023-04-03

发表评论

登录后才能评论

评论列表(0条)

    保存