Linux系统内存占用90%以上——解决方法

最近遇到一个疑问,不管是top,还是cat /proc/meminfo,  发现free内存基本快没了,难道我们的程序出问题了?排查半天没有事,

后来百度到相关帖子,记录一下,这是Linux内核机制,


Linux与Windows不同,会存在缓存内存,通常叫做Cache Memory。有些时候你会发现没有什么程序在运行,但是使用top或free命令看到可用内存会很少。
 
什么是Cache Memory(缓存内存):
 
当你读写文件的时候,Linux内核为了提高读写效率与速度,会将文件在内存中进行缓存,这部分内存就是Cache Memory(缓存内存)。即使你的程序运行结束后,Cache Memory也不会自动释放。这就会导致你在Linux系统中程序频繁读写文件后,你会发现可用物理内存会很少。
 
其实这缓存内存(Cache Memory)在你需要使用内存的时候会自动释放,所以你不必担心没有内存可用。如果你希望手动去释放Cache Memory(缓存内存)的话也是有办法的。
 
释放Cache Memory(缓存内存):
 
用下面的命令可以释放Cache Memory:
 
[rootmin@localhost~]#echo 3 > /proc/sys/vm/drop_caches
 
Linux中如何释放cache内存
 
因为LINUX的内核机制,一般情况下不需要特意去释放已经使用的cache。这些cache起来的内容可以增加文件以及的读写速度。
 
先说下free命令怎么看内存
 
[rootmin@localhost~]# free
 
total used free shared buffers cached
 
Mem: 515588 295452 220136 0 2060 64040
 
-/+ buffers/cache: 229352 286236
 
Swap: 682720 112 682608
 
其中第一行用全局角度描述系统使用的内存状况:
 
total——总物理内存 
 
used——已使用内存,一般情况这个值会比较大,因为这个值包括了cache+应用程序使用的内存
 
free——完全未被使用的内存
 
shared——应用程序共享内存
 
buffers——缓存,主要用于目录方面,inode值等(ls大目录可看到这个值增加)
 
cached——缓存,用于已打开的文件
 
注意:
 
total=used+free
 
used=buffers+cached (maybe add shared also)
 
第二行描述应用程序的内存使用:
 
前个值表示-buffers/cache——应用程序使用的内存大小,used减去缓存值
 
后个值表示+buffers/cache——所有可供应用程序使用的内存大小,free加上缓存值
 
注意
 
-buffers/cache=used-buffers-cached
 
+buffers/cache=free+buffers+cached
 
第三行表示swap的使用: 
 
used——已使用
 
free——未使用
 
cache释放:
 
1.   To free pagecache:
 
[rootmin@localhost~]#echo 1 > /proc/sys/vm/drop_caches
 
2.   To free dentries and inodes:
 
[rootmin@localhost~]#echo 2 > /proc/sys/vm/drop_caches
 
3.   To free pagecache, dentries and inodes:
 
[rootmin@localhost~]#echo 3 > /proc/sys/vm/drop_caches
 
说明,释放前最好sync一下,防止丢数据

你可能感兴趣的:(linux,Linux,内存,cached)