相信大家用CENTOS5.6搭建的LNMP平台都遇到过因为PHP进程开启过大,或者服务器遭遇高并发数的时候,内存被耗光导致服务器响应很慢的情况,采用网上类似的脚本改造了一下,在因为php-fpm或者mysql导致内存耗光85%的时候,脚本自动重启相关服务,脚本如下:

# 设置最大内存占用百分比
PID_MEM_MAX="85"

# 设置最大系统负载
SYS_LOAD_MAX="3"

# 设置需要监控的服务名称
NAME_LIST="php-fpm mysqld"

for NAME in $NAME_LIST
do
# 初始化内存统计
PID_MEM_SUM=0

# 获取该程序总进程数
PID_NUM_SUM=`ps aux | grep $NAME | wc -l`

# 列出每个进程内存占用百分比
PID_MEM_LIST=`ps aux | grep $NAME | awk '{print $4}'`

# 计算所有进程总内存占用
for PID_MEM in $PID_MEM_LIST
do
PID_MEM_SUM=`echo $PID_MEM_SUM + $PID_MEM | bc`
done

# 获取最近一分钟系统负载
SYS_LOAD=`uptime | awk '{print $(NF-2)}' | sed 's/,//'`

# 比较内存占用和系统负载是否超过阀值
MEM_VULE=`awk 'BEGIN{print('"$PID_MEM_SUM"'>='"$PID_MEM_MAX"'?"1":"0")}'`
LOAD_VULE=`awk 'BEGIN{print('"$SYS_LOAD"'>='"$SYS_LOAD_MAX"'?"1":"0")}'`

# 如果系统内存占用和系统负载超过阀值,则进行下面操作。
if [ $MEM_VULE = 1 ] || [ $LOAD_VULE = 1 ] ;then
# 写入日志
echo $(date +"%y-%m-%d %H:%M:%S") "killall $NAME" "(MEM:$PID_MEM_SUM,LOAD:$SYS_LOAD)">> /var/log/autoreboot.log
# 重启服务
/etc/init.d/service $NAME reload

#写入日志
echo $(date +"%y-%m-%d %H:%M:%S") "reload $NAME" "(MEM:$PID_MEM_SUM,LOAD:$SYS_LOAD)" >> /var/log/autoreboot.log
else
echo "$NAME very health!(MEM:$PID_MEM_SUM,LOAD:$SYS_LOAD)" > /dev/
fi
done

代码结束

以上代码保存为一个文件,例如:auto_reload.sh

添加计划任务,设置每分钟检查一次

crontab -e
* * * * * /bin/bash /root/auto_reload.sh

注意文件的位置要搞正确。