1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
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.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中剩余的内存低于20%的时候,该脚本才会执行,以防止oom kill掉mysql进程,最直接的手段还是加内存。
本文转自 dbapower 51CTO博客,原文链接:http://blog.51cto.com/suifu/1828050,如需转载请自行联系原作者