vi recover_mem.sh #!/bin/bash ################## #author:rrhelei@126.com# ################## #系統分配的區總量 mem_total=`free -m |grep Mem | awk '{print $2}'` #當前剩餘的free大小 mem_free=`free -m |grep Mem | 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 sync echo 1 > /proc/sys/vm/drop_caches # To free dentries and inodes: echo 2 > /proc/sys/vm/drop_caches # To free pagecache, dentries andinodes: echo 3 > /proc/sys/vm/drop_caches fi fi
before sh -x recover_mem.shnode
[root@HE3]# free -m
total used free shared buffers cached
Mem: 15948 14774 1173 0 130 7926
-/+ buffers/cache: 6717 9231
Swap: 0 0 0mysql
after sh -x recover_mem.shsql
[root@HE3]# free -m
total used free shared buffers cached
Mem: 15948 6603 9344 0 1 18
-/+ buffers/cache: 6582 9365
Swap: 0 0 0緩存
能夠看出,cache的緩存已被釋放。值得注意的是,cache被釋放後,對mysql性能影響比較明顯的,由於mysql須要從新cache,所以該腳本僅做救急用,只有當free中剩餘的內存低於20%的時候,該腳本纔會執行,以防止oom kill掉mysql進程,最直接的手段仍是加內存。bash