vi recover_mem.sh #!/bin/bash #系统分配的区总量 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.sh
[[email protected]]# free -m
total used free shared buffers cached
Mem: 15948 14774 1173 0 130 7926
-/+ buffers/cache: 6717 9231
Swap: 0 0 0
after sh -x recover_mem.sh
[[email protected]]# 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中剩余的内存低于10%的时候,该脚本才会执行,以防止oom kill掉mysql进程,最直接的手段还是加内存。
时间: 2024-11-08 07:35:39