监控 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