一、Linux的内存分配方式

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

二、释放内存

  1. 首先使用 free -m 查看剩余内存 在这里插入图片描述
  2. free -m 各参数含义

total:总物理内存
used: 已使用内存
free: 完全未被使用的内存
shared:应用程序共享内存
buffers:读缓存,主要用于目录方面,inode值等
cached:写缓存,用于已打开的文件的I/O操作
-buffers/cache:应用程序使用的内存大小,used减去缓存值
+buffers/cache:所有可供应用程序使用的内存大小,free加上缓存值
其中:
total = used + free
-buffers/cache=used-buffers-cached,这个是应用程序真实使用的内存大小
+buffers/cache=free+buffers+cached,这个是服务器真实还可利用的内存大小

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

    $ sync
    $ sync
    $ sync
    
  2. 修改 /proc/sys/vm/drop_caches

    $ 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.

      1. To free pagecache, use echo 1 > /proc/sys/vm/drop_caches;
      2. to free dentries and inodes, use echo 2 > /proc/sys/vm/drop_caches;
      3. to free pagecache, dentries and inodes, use echo 3 >/proc/sys/vm/drop_caches.
      4. Because this is a non-destructive operation and dirty objects are not freeable, the user should run sync first.
    3. Linux内核会将它最近访问过的文件页面缓存在内存中一段时间,这个文件缓存被称为pagecache。

  3. 再次查看在这里插入图片描述

Logo

更多推荐