ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

linux内存释放办法

2021-06-20 16:36:55  阅读:185  来源: 互联网

标签:释放 drop cached cache free 内存 linux buffers


在服务器运行过程中,使用free -m查看服务器内存时,经常会发现free值很小,有些同学就会很紧张,总想采取一些措施,使得free值看起来高一点,心里就比较爽一点。其实,个人觉得这完全是图一时之快,没什么实质性用途。

一、大众释放内存方法

1. 首先使用free -m查看剩余内存

  1. linux-8v2i:~ # free -m  
  2.              total       used       free     shared    buffers     cached  
  3. Mem:          3952       2773       178          0         130        1097  
  4. -/+ buffers/cache:       1545       2406  
  5. Swap:         2055          0       2055  

2. 执行sync命令

      使用sync命令以确保文件系统的完整性,sync 命令运行 sync 子例程,将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件。 
  1. linux-8v2i:~ # sync  

3. 修改/proc/sys/vm/drop_caches

  1. echo 3 > /proc/sys/vm/drop_caches  
  说明: 1>. /proc是一个虚拟文件系统,我们可以通过对它的读写操作作为与kernel实体间进行通信的一种手段。也就是说可以通过修改/proc中的文件,来对当前kernel的行为做出调整。也就是说我们可以通过调整/proc/sys/vm/drop_caches来释放内存。 2>. 关于drop_caches的官方说明如下: Writing to this file causes the kernel to drop clean caches,dentries and inodes from memory, causing that memory to becomefree. 

To free pagecache, use echo 1 > /proc/sys/vm/drop_caches; to free dentries and inodes, use echo 2 > /proc/sys/vm/drop_caches; 
to free pagecache, dentries and inodes, use echo 3 >/proc/sys/vm/drop_caches. 

Because this is a non-destructive operation and dirty objects are not freeable, the user should run sync first.   3>. Linux内核会将它最近访问过的文件页面缓存在内存中一段时间,这个文件缓存被称为pagecache。

4.再使用free -m查看剩余内存,情况如下:

  1. linux-8v2i:~ # free -m  
  2.              total       used       free     shared    buffers     cached  
  3. Mem:          3952       1773       2325          0         0        80  
  4. -/+ buffers/cache:       1545       2406  
  5. Swap:         2055          0       2055  
 

二、Linux内存分析

1. 首先对free -m查看结果进行分析

  1. linux-8v2i:~ # free -m  
  2.              total       used       free     shared    buffers     cached  
  3. Mem:          3952       2773       178          0         130        1097  
  4. -/+ buffers/cache:       1545       2406  
  5. Swap:         2055          0       2055  
  各参数含义:
  • total:总物理内存
  • used:已使用内存
  • free:完全未被使用的内存
  • shared:应用程序共享内存
  • buffers:缓存,主要用于目录方面,inode值等
  • cached:缓存,用于已打开的文件
  • -buffers/cache:应用程序使用的内存大小,used减去缓存值
  • +buffers/cache:所有可供应用程序使用的内存大小,free加上缓存值
  其中:
  • total = used + free
  • -buffers/cache=used-buffers-cached,这个是应用程序真实使用的内存大小
  • +buffers/cache=free+buffers+cached,这个是服务器真实还可利用的内存大小

2. Linux的内存分配方式

      大家都知道,Linux服务器为了提高效率,会提前申请内存,即使这些内存没有被具体应用使用,Linux也会提前申请这些内存,然后利用这些内存做缓存用,即将刚打开的文件系统存入cache中,这样对应的服务器free值会越来越少,buffers和cached会越来越大,因此给大家表象就是内存越来越少了,大家就紧张了;其实,大家完全不用紧张,Linux服务器在发现内存不足时,会自动清理cached区域,释放内存,然后继续增大cache,free继续减少。因此,那样手动降低内存使用率的方法,其实就是图一时之快,呵呵。

标签:释放,drop,cached,cache,free,内存,linux,buffers
来源: https://www.cnblogs.com/Leebo/p/14907042.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有