Linux下如何释放cache内存

转自:http://www.linuxidc.com/Linux/2015-02/112685.htm

在Linux下频繁存取文件后,物理内存会很快被用光,当程序结束后,内存不会被正常释放,而是一直作为caching.这个问题,貌似有不少人在问,不过都没有看到有什么很好解决的办法。那么我来谈谈这个问题。
 先来说说free命令

[[email protected] ~]# free -m
    total used free shared buffers cached
    Mem: 249 163 86 0 10 94 
    -/+ buffers/cache: 58 191
    Swap: 511 0 511

其中:
total 内存总数
used 已经使用的内存数
free 空闲的内存数
 
shared 多个进程共享的内存总额
buffers Buffer Cache和cached Page Cache 磁盘缓存的大小
-buffers/cache 的内存数:used - buffers - cached
 +buffers/cache 的内存数:free + buffers + cached
  
可用的memory=free memory+buffers+cached

有了这个基础后,可以得知,我现在used为163MB,free为86,buffer和cached分别为10,94
那么我们来看看,如果我执行复制文件,内存会发生什么变化。

[[email protected] ~]# cp -r /etc ~/test/
[[email protected] ~]# free -m

total used free shared buffers cached
 Mem: 249 244 4 0 8 174
-/+ buffers/cache: 62 187
 Swap: 511 0 511
  
在linux命令执行结束后,used为244MB,free为4MB,buffers为8MB,cached为174MB,天呐都被cached吃掉了。别紧张,这是为了提高文件读取效率的做法。
 
为了提高磁盘存取效率, Linux命令做了一些精心的设计, 除了对dentry进行缓存(用于VFS,加速文件路径名到inode的转换), 还采取了两种主要Cache方式:Buffer Cache和Page Cache。前者针对磁盘块的读写,后者针对文件inode的读写。这些Cache有效缩短了 I/O系统调用(比如read,write,getdents)的时间。“
 
那么有人说过段时间,Linux会自动释放掉所用的内存,我们使用free再来试试,看看是否有释放》?
 
[[email protected] test]# free -m
  
 total used free shared buffers cached
  
 Mem: 249 244 5 0 8 174
  
-/+ buffers/cache: 61 188
  
 Swap: 511 0 511
  
 MS没有任何变化,那么我能否手动释放掉这些内存呢???回答是可以的!
 
 /proc是一个虚拟文件系统,我们可以通过对它的读写操作做为与kernel实体间进行通信的一种手段。也就是说可以通过修改/proc中的文件,来对当前kernel的行为做出调整。那么我们可以通过调整/proc/sys/vm/drop_caches来释放内存。操作如下:
 
[[email protected] test]# cat /proc/sys/vm/drop_caches
  
 0
  
首先,/proc/sys/vm/drop_caches的值,默认为0
  
[[email protected] test]# sync
  
手动执行sync命令(描述:sync 命令运行 sync 子例程。如果必须停止系统,则运行 sync 命令以确保文件系统的完整性。sync 命令将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件)
 
[[email protected] test]# echo 3 》 /proc/sys/vm/drop_caches
  
[[email protected] test]# cat /proc/sys/vm/drop_caches
  
 3
  
将/proc/sys/vm/drop_caches值设为3
  
[[email protected] test]# free -m
  
 total used free shared buffers cached
  
 Mem: 249 66 182 0 0 11
  
-/+ buffers/cache: 55 194
  
 Swap: 511 0 511
  
再来运行free命令,发现现在的used为66MB,free为182MB,buffers为0MB,cached为11MB.那么有效的释放了buffer和cache.
  
有关/proc/sys/vm/drop_caches的用法在下面进行了说明
 
 /proc/sys/vm/drop_caches (since Linux 2.6.16)
 
Writing to this file causes the kernel to drop clean caches,
 
dentries and inodes from memory, causing that memory to become
  
 free.
  
 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

时间: 2024-10-13 23:41:04

Linux下如何释放cache内存的相关文章

Linux下程序运行时内存状态及相应查看工具

最近在解决一个编译问题时,一直在考虑一个问题,那就是Linux下可执行程序运行时内存是什么状态,是按照什么方式分配内存并运行的.查看了一下资料,就此总结一下,众所周知,linux下内存管理是通过虚存管理的,在分配内存是并非在物理内存开辟了一段空间,而是在使用时才分配的,而且是通过段页式管理.以上比较废话,开始看看程序运行时内存会是什么状态. 在linux下内存分配是以页为单位的,而页是通过段管理,各个段之间是独立的,方便管理.linux程序运行时,可以分为以下几个内存段: 一.BSS段 (bss

linux下对进程按照内存使用情况进行排序

linux下对进程按照内存使用情况进行排序的命令为:ps aux --sort -rss 详细解说参见 http://alvinalexander.com/linux/unix-linux-process-memory-sort-ps-command-cpu

linux下怎样释放内存、swap分区满的情况

在Linux系统下,我们一般不需要去释放内存,因为系统已经将内存管理的很好.但是凡事也有例外,有的时候内存会被缓存占用掉,导致系统使用SWAP空间影响性能,此时就需要执行释放内存(清理缓存)的操作了. Linux系统的缓存机制是相当先进的,他会针对dentry(用于VFS,加速文件路径名到inode的转换).Buffer Cache(针对磁盘块的读写)和Page Cache(针对文件inode的读写)进行缓存操作.但是在进行了大量文件操作之后,缓存会把内存资源基本用光.但实际上我们文件操作已经完

Linux下查看CPU和内存(很详细)

在系统维护的过程中,随时可能有需要查看 CPU 使用率,并根据相应信息分析系统状况的需要.在 CentOS 中,可以通过 top 命令来查看 CPU 使用状况.运行 top 命令后,CPU 使用状态会以全屏的方式显示,并且会处在对话的模式 -- 用基于 top 的命令,可以控制显示方式等等.退出 top 的命令为 q (在 top 运行中敲 q 键一次). top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器 可以直接使用top命

【转】Linux 下取进程占用 cpu/内存 最高的前10个进程

# Linux 下 取进程占用 cpu 最高的前10个进程ps aux|head -1;ps aux|grep -v PID|sort -rn -k +3|head # linux 下 取进程占用内存(MEM)最高的前10个进程ps aux|head -1;ps aux|grep -v PID|sort -rn -k +4|head 转自:http://blog.csdn.net/namesliu/article/details/6037972

linux下查看cpu,内存,硬盘等硬件信息的方法

说明:Linux下可以在/proc/cpuinfo中看到每个cpu的详细信息.但是对于双核的cpu,在cpuinfo中会看到两个cpu.常常会让人误以为是两个单核的cpu. 原文地址: http://www.hpboys.com/659.html 一.linux CPU大小 [root@idc ~]# cat /proc/cpuinfo |grep "model name" && cat /proc/cpuinfo |grep "physical id&quo

Linux下直接读写物理地址内存

虚拟 转 物理地址  virt_to_phys( *addr );物理 转 虚拟地址  phys_to_virt( *addr ); 如: unsigned long pProtectVA; phys_addr_t ProtectPA; gM4U_ProtectVA = pProtectVA; ProtectPA = virt_to_phys((void *)pProtectVA); -------------------------------------------------Linux内核

linux 下取进程占用 cpu/内存 最高的前10个进程

1. linux 下 取进程占用 cpu 最高的前10个进程ps aux|head -1;ps aux|grep -v PID|sort -rn -k +3|head ps auxw|head -1;ps auxw|sort -rn -k3|head -10 2.linux 下 取进程占用内存(MEM)最高的前10个进程ps aux|head -1;ps aux|grep -v PID|sort -rn -k +4|head ps auxw|head -1;ps auxw|sort -rn -k

linux 释放cache 内存

释放内存前 # free -m             total       used       free     shared    buffers     cachedMem:          7831       7704        127          0        256       6813-/+ buffers/cache:        634       7197Swap:         7999          0       7999 sync &&am