增加定時檢測linux占用內存,及時清理功能
原文:http://www.voidcn.com/article/p-wnmannom-boa.html
free -m 查看,發現內存跑滿了。
再 top,然后按下shift+m,也就是按內存占用百分比排序,發現排在第一的進程,才占用7.9%。
但是總內存大小8G,竟然有5G都被使用了,
那是什么占用的呢?
百度了一下,據說是centos為了提高效率,把部分使用過的文件緩存到了內存里。
如果是這樣的話,我又不需要這樣的文件性能,那就可以釋放。如下兩個命令就可以:
#sync
#echo 3 > /proc/sys/vm/drop_caches
內存釋放后,就占用很低了,
寫一個腳本,然后使用crontab定時沒分鍾執行一次,檢測內存量使用超過80%的時候報警,釋放內存,
釋放內存腳本如下:
#!/bin/bash #系統分配的區總量 mem_total=`free -m | awk 'NR==2' | awk '{print $2}'` #當前剩余的大小 mem_free=`free -m | awk 'NR==3' | awk '{print $4}'` #當前已使用的used大小 mem_used=`free -m | grep Mem | awk '{print $3}'` if (($mem_used != 0)); then #如果已被使用,則計算當前剩余free所占總量的百分比,用小數來表示,要在小數點前面補一個整數位0 mem_per=0`echo "scale=2;$mem_free/$mem_total" | bc` DATA="$(date -d "today" +"%Y-%m-%d-%H-%M") free percent is : $mem_per" echo $DATA >> /var/log/mem_detect.log #設置的告警值為20%(即使用超過80%的時候告警)。 mem_warn=0.20 #當前剩余百分比與告警值進行比較(當大於告警值(即剩余20%以上)時會返回1,小於(即剩余不足20%)時會返回0 ) mem_now=`expr $mem_per \> $mem_warn` #如果當前使用超過80%(即剩余小於20%,上面的返回值等於0),釋放內存 if (($mem_now == 0)); then sync echo 1 > /proc/sys/vm/drop_caches echo 2 > /proc/sys/vm/drop_caches echo 3 > /proc/sys/vm/drop_caches #將release memory OK !寫入temp文件夾的memstat_日期.log日志中 echo "--->release memory OK ! " >>temp/memstat_$(date +%Y%m%d_%H%M%S).log fi fi
下面說一下怎么使用定時:
一. Crontab 介紹
crontab命令的功能是在一定的時間間隔調度一些命令的執行。
二.查看/etc/crontab文件
vim /etc/crontab
在crontab中增加定時任務
三.文件/etc/crontab中每行任務的描述格式如下:
minute hour day month dayofweek command
minute - 從0到59的整數
hour - 從0到23的整數
day - 從1到31的整數 (必須是指定月份的有效日期)
month - 從1到12的整數 (或如Jan或Feb簡寫的月份)
dayofweek - 從0到7的整數,0或7用來描述周日 (或用Sun或Mon簡寫來表示)
command - 需要執行的命令(可用as ls /proc >> /tmp/proc或 執行自定義腳本的命令)
如果是每五分鍾執行一次可改為:
*/5 * * * * /home/dbbackup/db2backup.sh
四.crontab服務的啟動關閉
sbin/service crond start //啟動服務 /sbin/service crond stop //關閉服務 /sbin/service crond restart //重啟服務 /sbin/service crond reload //重新載入配置
代碼如下:
#!/bin/bash
echo "current time is $(date -d "today" +"%Y-%m-%d-%H-%M-%S")" >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
#系統分配的區總量
mem_total=`free | grep "Mem:" |awk '{print $2}'`
echo "mem_total is $mem_total " >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
#當前剩余的大小
mem_free=`free | grep 'buffers/cache' | awk '{print $3}'`
echo "mem_free is $mem_free" >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
#當前已使用的used大小
mem_used=`free -m | grep Mem | awk '{print $3}'`
echo "mem_used is $mem_used" >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
if (($mem_used != 0)); then
#如果已被使用,則計算當前剩余free所占總量的百分比,用小數來表示,要在小數點前面補一個整數位0
mem_per=0`echo "scale=2;$mem_free/$mem_total" | bc`
echo "free percent is $mem_per" >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
DATA="$(date -d "today" +"%Y-%m-%d-%H-%M-%S") free percent is : $mem_per"
echo $DATA >> /usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
echo $DATA >> /var/log/mem_detect.log
#設置的告警值為44%(即使用超過56%的時候告警)。
mem_warn=0.4
echo "mem_warn is $mem_warn" >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
#當前剩余百分比與告警值進行比較(當大於告警值(即剩余44%以上)時會返回1,小於(即剩余不足44%)時會返回0 )
mem_now=`expr $mem_per \> $mem_warn`
echo "剩余百分比與警告值比較 mem_now is $mem_now" >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
echo "when mem_now is 1 , means mem is ok ! " >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
echo "-----------------------------------" >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
#如果當前使用超過56%(即剩余小於44%,上面的返回值等於0),釋放內存
if (($mem_now == 0)); then
echo "but now the mem_now is 0 ,小於(即內存剩余不足44%),所以清理內存, start to clear memery....." >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
sync
echo 1 > /proc/sys/vm/drop_caches
echo 2 > /proc/sys/vm/drop_caches
echo 3 > /proc/sys/vm/drop_caches
echo "---> start auto clear memery is OK ! $DATA , warn is $mem_warn ,小於(即內存剩余不足44%),所以清理內存, " >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d_%H).log
fi
#取當前空閑cpu百份比值(只取整數部分)
cpu_idle=`top -b -n 1 | grep Cpu | awk '{print $5}' | cut -f 1 -d "."`
echo "cpu_idle percent is $cpu_idle,cpu 剩余量充足,警告值是當剩余不足30%時,自動清理內" >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
echo "================================================================" >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log
#設置空閑cpu的告警值為30%,如果當前cpu使用超過70%(即剩余小於30%),立即發郵件告警,自動清理內存
if (($cpu_idle < 30)); then echo " cpu 剩余不足30% ,所以清理內存, start to clear memery....." >>/usr/local/tomcat/logs/monitor/mem_auto_$(date +%Y%m%d).log sync echo 1 > /proc/sys/vm/drop_caches echo 2 > /proc/sys/vm/drop_caches echo 3 > /proc/sys/vm/drop_caches echo "--->cpu used more than 70% ,so start auto clear memery is OK ! $DATA , warn is $mem_warn " >>/usr/local/tomcat_treasure/logs/memery_monitor/memstat_cpu_auto_$(date +%Y%m%d_%H).log fi fi