Linux指定定时脚本清理缓存、查看内存使用情况

转载地址,部分补充修改。


Linux命令之sync - 强制将内存中的文件缓冲内容写到磁盘。
Linux内核为了达到最佳的磁盘操作效率,会把需要写入到磁盘的数据现在内存中缓存起来,在合适的时候才真正写入到磁盘中,这在绝大多数情况都是没有任何问题的,而且提高了系统的效率,但是如果系统当机、掉电,就会有些文件内容不会保存下来。在Linux系统关机或者重启时,会自动把缓冲区的内容自动同步到磁盘中。我们也可以手工去执行sync命令,强制将内存中的文件缓冲内容写到磁盘,这个命令是通过调用sync系统调用来实现的。


常用方式 : sync —— 强制将内存中的文件缓冲内容写到磁盘。

脚本例子内容如下:

 crontab -e

 */1 * * * * /root/drop_cacheFile.sh >>/root/cronDropCache.log

#/bin/bash
mt=`free | tr [:blank:] \\\n | grep [0-9] | sed -n '1p'`
mu=`free | tr [:blank:] \\\n | grep [0-9] | sed -n '2p'`
mf=`free | tr [:blank:] \\\n | grep [0-9] | sed -n '3p'`
st=`free | tr [:blank:] \\\n | grep [0-9] | sed -n '9p'`
su=`free | tr [:blank:] \\\n | grep [0-9] | sed -n '10p'`
sf=`free | tr [:blank:] \\\n | grep [0-9] | sed -n '11p'`
t=`expr $mt + $st`
u=`expr $mu + $su`
R=`expr $mu \* 100 / $mt`
nowdata=`date "+%Y-%m-%d %H:%M:%S"`


echo "========"$nowdata"执行我清理内存啦====================="
echo "当前内存使用率为: $R%"
ttotle=`free -m |awk '{if(NR>1 && NR<3) {print $2}}'`
uused=`free -m |awk '{if(NR>1 && NR<3) {print $3}}'`
ffree=`free -m |awk '{if(NR>1 && NR<3) {print $4}}'`
echo "目前的内存情况M单位:总内存:"$ttotle"M--使用了:"$uused"M--剩余:"$ffree"M"
echo 3 > /proc/sys/vm/drop_caches

echo "内存清理结束"


在Linux系统下,我们一般不需要去释放内存,因为系统已经将内存管理的很好。但是凡事也有例外,有的时候内存会被缓存占用掉,导致系统使用SWAP空间影响性能,此时就需要执行释放内存(清理缓存)的操作了。

Linux系统的缓存机制是相当先进的,他会针对dentry(用于VFS,加速文件路径名到inode的转换)、Buffer Cache(针对磁盘块的读写)和Page Cache(针对文件inode的读写)进行缓存操作。但是在进行了大量文件操作之后,缓存会把内存资源基本用光。但实际上我们文件操作已经完成,这部分缓存已经用不到了。这个时候,我们难道只能眼睁睁的看着缓存把内存空间占据掉么?

所以,我们还是有必要来手动进行Linux下释放内存的操作,其实也就是释放缓存的操作了。

要达到释放缓存的目的,我们首先需要了解下关键的配置文件/proc/sys/vm/drop_caches。这个文件中记录了缓存释放的参数,默认值为0,也就是不释放缓存。他的值可以为0~3之间的任意数字,代表着不同的含义:

0 – 不释放
1 – 释放页缓存
2 – 释放dentries和inodes
3 – 释放所有缓存


1.清理前内存使用情况 
free -m

2.开始清理  
echo 1 > /proc/sys/vm/drop_caches
3.清理后内存使用情况 
free -m
4.完成! 查看内存条数命令:

dmidecode | grep -A16 "Memory Device$"


定时脚本添加执行任务可参考原文:http://blog.csdn.net/liqi_q/article/details/78044373

关于清理缓存、写入物理内存的库函数fsync(),参考Linux下文件写操作,异常断电,文件丢失

猜你喜欢

转载自blog.csdn.net/Brouce__Lee/article/details/81937731