[iyunv@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
执行结果如下:
[iyunv@localhost baby]# sh check_mysql.sh
Starting MySQL SUCCESS! 改名之后执行为正常结果:
[iyunv@localhost baby]# mv check_mysql.sh check_db.sh
[iyunv@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
[iyunv@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
执行结果如下:
[iyunv@localhost baby]# sh check_db_client.sh
MySQL is running