在网上查了不少资料,弄了个脚本来监控服务器负载,超负荷 就自动重启apache,mysql的脚本,
适用于centos系统,和自带apache 和mysql,自定义编译安装的可能需要稍作调整。
linux时间也是个问题,此脚本也添加了连接时间服务器同步校对时间。
/usr/sbin/ntpdate cn.pool.ntp.org >> /backup/gaige/upClock.log 2>&1 && /sbin/hwclock -w
现在分享给大家:
需要用的朋友,可以在你的终端,运行一下代码,就会自动装到你的服务器。
wget http://www.xiangguoqi.com/cmd/restart_apa_my_by_load.sh; sh restart_apa_my_by_load.sh
装好后自动脚本和运行日志会在您服务器 /backup/gaige/ 下边,你可以自行调整。
默认自动是3分钟,你可以自行 crontab -e 修改
*/3 * * * * /backup/gaige/loadavg_restart_apache.sh >> /backup/gaige/restart_apache.log
-------------------
手动安装脚本如下:
把以下代码为sh脚本
#!/bin/sh
# crontab: */3 * * * * /backup/gaige/loadavg_restart_apache.sh >> /backup/gaige/restart_apache.log
/usr/sbin/ntpdate cn.pool.ntp.org >> /backup/gaige/upClock.log 2>&1 && /sbin/hwclock -w
sync
sync
echo 3 > /proc/sys/vm/drop_caches
TOP_SYS_LOAD_NUM=5
SYS_LOAD_NUM=`uptime | awk '{print $(NF-2)}' | sed 's/,//'`
echo $(date +"%y-%m-%d") `uptime`
if [ `echo "$TOP_SYS_LOAD_NUM < $SYS_LOAD_NUM"|bc` -eq 1 ]
then
sync
echo "#0#" $(date +"%y-%m-%d %H:%M:%S") "pkill httpd" `ps -ef | grep httpd | wc -l`
echo "#0#" $(date +"%y-%m-%d %H:%M:%S") "pkill mysqld" `ps -ef | grep mysqld | wc -l`
/usr/sbin/apachectl stop
service mysqld stop
sleep 8
pkill httpd
pkill mysqld
sleep 8
for i in 1 2 3
do
if [ `pgrep mysqld | wc -l` -le 0 ]
then
/sbin/service mysqld start
sleep 30
echo "#1#" $(date +"%y-%m-%d %H:%M:%S") "start mysqld" `ps -ef | grep mysqld | wc -l`
fi
if [ `pgrep httpd | wc -l` -le 0 ]
then
/usr/sbin/apachectl start
sleep 30
echo "#1#" $(date +"%y-%m-%d %H:%M:%S") "start httpd" `ps -ef | grep httpd | wc -l`
fi
done
else
if [ `pgrep mysqld | wc -l` -le 0 ]
then
/sbin/service mysqld start
sleep 30
echo "#2#" $(date +"%y-%m-%d %H:%M:%S") "start mysqld" `ps -ef | grep mysqld | wc -l`
fi
if [ `pgrep httpd | wc -l` -le 0 ]
then
/usr/sbin/apachectl start
sleep 30
echo "#2#" $(date +"%y-%m-%d %H:%M:%S") "start httpd" `ps -ef | grep httpd | wc -l`
fi
fi
然后在
crontab -e
添加
*/3 * * * * /backup/gaige/loadavg_restart_apa_my.sh >> /backup/gaige/restart_apa_my.log
*/3 ***** 表示3分钟,/backup/gaige/loadavg_restart_apa_my 你可以自定义。
#!/bin/sh
# crontab: */3 * * * * /www/wdlinux/tools/loadavg_restart_apache.sh >> /var/log/restart_apache.log
/usr/sbin/ntpdate cn.pool.ntp.org >> /var/log/upClock.log 2>&1 && /sbin/hwclock -w
sync
sync
echo 3 > /proc/sys/vm/drop_caches
TOP_SYS_LOAD_NUM=5
SYS_LOAD_NUM=`uptime | awk '{print $(NF-2)}' | sed 's/,//'`
echo $(date +"%y-%m-%d") `uptime`
if [ `echo "$TOP_SYS_LOAD_NUM < $SYS_LOAD_NUM"|bc` -eq 1 ]
then
sync
echo "#0#" $(date +"%y-%m-%d %H:%M:%S") "pkill httpd" `ps -ef | grep httpd | wc -l`
echo "#0#" $(date +"%y-%m-%d %H:%M:%S") "pkill mysqld" `ps -ef | grep mysqld | wc -l`
service httpd stop
service mysqld stop
sleep 8
pkill httpd
pkill mysqld
sleep 8
for i in 1 2 3
do
if [ `pgrep mysqld | wc -l` -le 0 ]
then
/sbin/service mysqld start
sleep 30
echo "#1#" $(date +"%y-%m-%d %H:%M:%S") "start mysqld" `ps -ef | grep mysqld | wc -l`
fi
if [ `pgrep httpd | wc -l` -le 0 ]
then
service httpd start
service wdapache start
sleep 30
echo "#1#" $(date +"%y-%m-%d %H:%M:%S") "start httpd" `ps -ef | grep httpd | wc -l`
fi
done
else
if [ `pgrep mysqld | wc -l` -le 0 ]
then
/sbin/service mysqld start
sleep 30
echo "#2#" $(date +"%y-%m-%d %H:%M:%S") "start mysqld" `ps -ef | grep mysqld | wc -l`
fi
if [ `pgrep httpd | wc -l` -le 0 ]
then
service httpd start
service wdapache start
sleep 30
echo "#2#" $(date +"%y-%m-%d %H:%M:%S") "start httpd" `ps -ef | grep httpd | wc -l`
fi
fi
将以上文件,保存在 /www/wdlinux/tools/loadavg_restart_apa_my.sh
然后在
crontab -e
添加
*/3 * * * * /www/wdlinux/tools/loadavg_restart_apa_my.sh >> /var/log/restart_apa_my.log
*/3 ***** 表示3分钟,/www/wdlinux/tools/loadavg_restart_apa_my 你可以自定义。
欢迎光临 WDlinux官方论坛 (http://www.wdlinux.cn/bbs/) | Powered by Discuz! 7.2 |