增加定時檢測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
轉載于:https://www.cnblogs.com/liujiacai/p/7821414.html