监控MySQL服务是否正常,通常的思路为:检查3306端口是否启动,ps查看mysqld进程是否启动,命令行登录mysql执行语句返回结果,php或jsp程序检测(需要开发人员开发程序)等等;
方法1:监听3306端口
1 2 3 4 5 6 7 8 9 10 | #!/bin/bash #written by mofansheng@2015-10-15 port=` netstat -nlt| grep 3306| wc -l` if [ $port - ne 1 ] then /etc/init .d /mysqld start else echo "MySQL is running" fi |
方法2:查看mysqld进程
注意注意:如果使用进程过滤的话,脚本名称如果里面包含mysql的话,脚本执行有坑,切记!!!因为会把脚本也grep了一次,导致结果不准确;
1 2 3 4 5 6 7 8 9 10 11 | [root@localhost baby] # cat check_mysql.sh #!/bin/bash #written by mofansheng@2015-10-15 process=` ps -ef | grep mysql| grep - v grep | wc -l` if [ $process - ne 2 ] then /etc/init .d /mysqld start else echo "MySQL is running" fi |
执行结果如下:
[root@localhost baby]# sh check_mysql.sh
Starting MySQL SUCCESS!
改名之后执行为正常结果:
[root@localhost baby]# mv check_mysql.sh check_db.sh
[root@localhost baby]# sh check_db.sh
MySQL is running
方法3:双保险,进程和端口都成功才算mysql服务正常
1 2 3 4 5 6 7 8 9 10 11 | #!/bin/bash #written by mofansheng@2015-10-15 port=` netstat -nlt| grep 3306| wc -l` process=` ps -ef | grep mysql| grep - v grep | wc -l` if [ $port - eq 1 ] && [ $process - eq 2 ] then echo "MySQL is running" else /etc/init .d /mysqld start fi |
4:使用客户端登录mysql执行命令,查看返回结果测试服务是否启动,理论上此方法最可靠。
1 2 3 4 5 6 7 8 9 10 11 | [root@localhost baby] # cat check_db_client.sh #!/bin/bash #written by mofansheng@2015-10-15 mysql -uroot -p123456 -e "select version();" &> /dev/null if [ $? - ne 0 ] then /etc/init .d /mysqld start else echo "MySQL is running" fi |
执行结果如下:
[root@localhost baby]# sh check_db_client.sh
MySQL is running
本文转自 模范生 51CTO博客,原文链接:http://blog.51cto.com/mofansheng/1703285,如需转载请自行联系原作者