码迷,mamicode.com
首页 > 系统相关 > 详细

Linux释放内存脚本

时间:2016-07-20 15:07:03      阅读:259      评论:0      收藏:0      [点我收藏+]

标签:释放内存脚本   mysql out of memory   

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

[root@HE3]# 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

[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中剩余的内存低于10%的时候,该脚本才会执行,以防止oom kill掉mysql进程,最直接的手段还是加内存。

本文出自 “岁伏” 博客,请务必保留此出处http://suifu.blog.51cto.com/9167728/1828050

Linux释放内存脚本

标签:释放内存脚本   mysql out of memory   

原文地址:http://suifu.blog.51cto.com/9167728/1828050

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!