您的位置:首页 > 运维架构 > Linux

如何判断Linux系统是否要添加内存

2014-04-07 14:02 423 查看

如何判断Linux系统是否要添加内存

分类: Linux2012-09-06 11:03367人阅读评论(0)收藏举报linuxcache磁盘bufferwindowsxpLinux的内存使用机制跟windows不同。正由于它们的使用机制不同,造成很多人都会说“为什么Linux使用的内存这么高?”
他说,他1G的内在free才232M,而win xp才用200M的样子。
其实啊,Linux的内存是很说究的。如下命令free是显示的当前内存的使用,-m参数的意思是M字节来显示内容。我们来一起看看。$ free -m
total used free shared buffers cached
Mem: 1002 769 232 0 62 421
-/+ buffers/cache:286 715
Swap: 1153 0 1153
第一部分Mem行:
total :表示物理内存总量。
used :表示总计分配给缓存(包含buffers 与cache )使用的数量,但其中可能部分缓存并未实际使用。
free :未被分配的内存。
shared :共享内存,一般系统不会用到,这里也不讨论。
buffers Buffer :系统分配但未被使用的buffers 数量。
cached Page :系统分配但未被使用的cache 数量。
第二部分(-/+ buffers/cache):
(-buffers/cache) used:实际使用的内存总量。(指的第一部分Mem行中的used – buffers – cached)
(+buffers/cache) free:当前实际可用内存。 (指的第一部分Mem行中的free + buffers + cached)
对应用程序来讲(-/+ buffers/cach)与buffers/cached是等同可用的,因为buffer/cached是为了提高程序执行的性能,当程序使用内存时,buffer/cached会很快地被使用。只是buffers和cached的产生是预分配的空间,它们没有真正使用到内存。而-buffers/cache反映的是被程序实实在在用掉的内存,而+buffers/cache反映的是可以挪用的内存总数。
所以我们看内存是否够用,就看(-/+ buffers/cache)的free和used的值。第三部分是指交换分区(swap)
当物理内存不够用时,系统为了程序的运行稳定,设立了临时的数据交换分区,以充当内存来使用。它是直接读写磁盘的,因此用到它时处理速度会变慢。如果严重过度使用swap会造成磁盘IO的性能消耗,导致整个系统缓慢,甚至崩溃。
从这里也可以便认出内存是否够用,因为一般情况下系统是以内存为主要使用,内存够用情况下是不会使用到swap分区的。如果你以现swap分区被大量使用了,那也证明你的内存不够用了。
这里又会产生一种特殊情况:
  $ free -m
   total used free shared buffers cached
  Mem: 1002 769 232 0 62 421
-/+ buffers/cache:610 392
  Swap: 1153 500 653

这种情况从上面的解释,你肯定认为是内存不够用了。其实这样认为也不完全错误,但内存确实还剩余393M,这是为什么呢?
原因是Linux系统内存和swap的使用策略,当内存使用到一定程度时(并不是完全用光),就开始使用swap。如果你的机器是大内存的话,你会见到第二行free会很多,也代表真实内存还有很多空闲,而swap又使用了一半,这时你要想办法释放swap,因为过度使用它是会造成性能剧降。你可以调整内存和swap使用的优先度,以下参数:
echo 10 > /proc/sys/vm/swappiness
echo “vm.swappiness=10″ >> /etc/sysctl.conf
sysctl -p

说明:vm.swappiness的值越小,表示系统更优先使用内存,越大表示优先使用swap,系统默认的值为60。以上修改完成后,重启机器或者占用内存较大的用户进程令它生效。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息