linux cached为什么一直不释放?
当读写文件的时候,Linux内核为了提高读写效率与速度,会将文件在内存中进行缓存,这部分内存就是Cache Memory(缓存内存)。即使你的程序运行结束后,Cache Memory也不会自动释放。缓存内存(Cache Memory)在你需要使用内存的时候会自动释放,所以不必担心没有内存可用。当然也可以手动释放:
echo 1 > /proc/sys/vm/drop_caches
echo 2 > /proc/sys/vm/drop_caches
echo 3 > /proc/sys/vm/drop_caches
注意:生产环境请谨慎操作。
linux 内存清理caches是什么?
linux内存清理caches是对内存之外的储存空间,也就是系统自带的高速缓存进行清理的一种功能。
当linux第一次读取一个文件运行时,一份放到一片内存中cache起来,另一份放入运行程序的内存中,正常运行,当程序运行完,关闭了,cache中的那一分却没有释放,第二次运行的时候,系统先看看在内存中是否有一地次运行时存起来的cache中的副本,如果有的话,直接从内存中读取,那样,速度就快多了。
说明这种情况的很典型的例子是启动firefox,由于firefox程序很大,因此第一次读取运行的时候很慢,尤其在速度不快的机器上,但是当你彻底关闭了firefox,ps看不到一个firefox进程,第二次再启动的时候就比第一次明显快很多,这是由于这次系统是直接从cache中读取的firefox来运行,并不是从磁盘上读取的。
再有一个例子:我们频繁使用的ls命令等基本命令,你运行的时候根本看不到硬盘灯闪,因为这些常用的命令都是再第一次运行后就保存在cache中的,以后就一直从内存中读出来运行。
如果cache占用的内存过多了,影响正常运行程序需要的内存,那么会释放掉一部分cache内存,但是总量会保持一个很高的值,所以,linux总是能最大限度的使用内存,就算加到16G,32G内存,也会随着不断的IO操作,内存的free值会慢慢减少到只有几M,想要内存不发生这种情况,只有一个办法:把内存加到比硬盘大。
linux清理内存空间?
1、使用free命令查看一下当前内存使用情况
free total used free shared buffers cachedMem: 16621896 8967952 7653944 0 212352 8377276-/+ buffers/cache: 378324 16243572Swap: 10241428 0 10241428#针对free命令后出现的信息解释#total:总计物理内存的大小#used:已使用多大#free:可用有多少#Shared:多个进程共享的内存总额#Buffers/cached:磁盘缓存的大小
2、执行sync同步数据
sync#该命令将未写的系统缓冲区写到磁盘中#包含已修改的 i-node、已延迟的块 I/O 和读写映射文件。
3、清理cache(缓存)
echo 3 > /proc/sys/vm/drop_caches freetotal used free shared buffers cachedMem: 16621896 579592 16042304 0 268 308708-/+ buffers/cache: 270616 16351280Swap: 10241428 0 10241428
4、对比步骤1和3的free命令,used(减少)、free(增大)对应Mem部分就清楚了,cache(缓存)被清理掉了。
ubuntu没有分配交换空间,内存被缓存快满了,有事吗?
如果你的内存够大,比如有2G,那不开交换分区也无所谓的了。
LINUX使用内存和WINDOWS使用内存的机制不一样,平时内存占满是正常的。LINUX优先使用内存做缓存,然后使用交换空间做缓存。麦麦的不老阁
Linux用户进程是如何释放内存的?
如果内存够,进程不去主动回收,内存是不会释放的Linux系统的缓存机制是相当先进的,他会针对dentry(用于VFS,加速文件路径名到inode的转换)、BufferCache(针对磁盘块的读写)和PageCache(针对文件inode的读写)进行缓存操作。
但是在进行了大量文件操作之后,缓存会把内存资源基本用光。但实际上我们文件操作已经完成,这部分缓存已经用不到了。