CentOS下编写shell脚本来监控MySQL主从复制的教程_MySQL
来源:互联网 发布:ntfs for mac 知乎 编辑:程序博客网 时间:2024/05/29 09:14
1、创建脚本文件
1
vi
/home/crontab/check_mysql_slave
.sh
#编辑,添加下面代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#!/bin/sh
# check_mysql_slave status
ip=eth0 #网卡名称
mysql_binfile=/usr/local/mysql/bin/mysql
mysql_user=root #MySQL数据库账号
mysql_pass=123456 #密码
mysql_sockfile=/tmp/mysql.sock
datetime=`date +"%Y-%m-%d/%H:%M:%S"` #获取当前时间
mysql_slave_logfile=/home/logs/check_mysql_slave.log #日志文件路径,必须提前创建好
slave_ip=`ifconfig $ip|grep "inet addr" | awk -F[:" "]+ '{print $4}'`
status=$($mysql_binfile -u$mysql_user -p$mysql_pass -S
$mysql_sockfile -e "show slave status\G" | grep -i "running")
Slave_IO_Running=`echo $status | grep Slave_IO_Running | awk ' {print $2}'`
Slave_SQL_Running=`echo $status | grep Slave_SQL_Running | awk '{print $2}'`
if [ "$Slave_IO_Running" = "Yes" -a "$Slave_SQL_Running" = "Yes" ]
then echo "Slave is Running!"
else
echo " $datetime $slave_ip Slave is not running!" >> $mysql_slave_logfile
$mysql_binfile -u$mysql_user -p$mysql_pass -S $mysql_sockfile -e "SLAVE STOP;"
$mysql_binfile -u$mysql_user -p$mysql_pass -S $mysql_sockfile -e "SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;"
$mysql_binfile -u$mysql_user -p$mysql_pass -S $mysql_sockfile -e "SLAVE START;"
$mysql_binfile -u$mysql_user -p$mysql_pass -S $mysql_sockfile -e "EXIT"
fi
1
2
3
:wq!
#保存退出
chmod
+x
/home/crontab/check_mysql_slave
.sh
#添加脚本执行权限
2、添加任务计划,修改/etc/crontab
1
2
3
4
5
vi
/etc/crontab
#在最后一行添加
*
/10
* * * * root
/home/crontab/check_mysql_slave
.sh
#表示每10分钟执行一次
:wq!
#保存退出
3、重新启动crond使设置生效
1
2
3
4
5
/etc/rc
.d
/init
.d
/crond
restart
#yum install -y vixie-cron安装计划任务,某些系统上可能没有预装
chkconfig crond on
#设为开机启动
service crond start
#启动
可以根据日志文件/home/logs/check_mysql_slave.log查看MySQL主从同步状态
PS:接下来这个脚本增加了“当发现同步出现无法同步的时候”会自动提取主库的file号,以及pos,进行同步主库,脚本内容如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#!/bin/sh
#set -x
#file is slave_repl.sh
#Author by Kevin
#date is 2011-11-13
mstool=
"/usr/local/mysql-3307/bin/mysql -h 192.168.1.106 -uroot -pw!zl7POg27 -P 3307"
sltool=
"/usr/local/mysql-3307/bin/mysql -h 192.168.1.107 -uroot -pw!zl7POg27 -P 3307"
declare
-a slave_stat
slave_stat=($($sltool -e
"show slave status\G"
|
grep
Running |
awk
'{print $2}'
))
if
[
"${slave_stat[0]}"
=
"Yes"
-a
"${slave_stat[1]}"
=
"Yes"
]
then
echo
"OK slave is running"
exit
0
else
echo
"Critical slave is error"
echo
echo
"*********************************************************"
echo
"Now Starting replication with Master Mysql!"
file
=`$mstool -e
"show master status\G"
|
grep
"File"
|
awk
'{print $2}'
`
pos=`$mstool -e
"show master status\G"
|
grep
"Pos"
|
awk
'{print $2}'
`
$sltool -e "slave stop;change master to master_host=
'192.168.1.106'
,
master_port=3307,master_user=
'repl'
,
master_password=
'w!zl7POg27'
,
master_log_file=
'$file'
,
master_log_pos=$pos;slave start;"
sleep
3
$sltool -e
"show slave status\G;"
|
grep
Running
echo
echo
"Now Replication is Finished!"
echo
echo
"**********************************************************"
exit
2
fi
运行后效果,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
# ./slave_stop3307.sh
*******************************
Now stop Slave Replication!
Slave_IO_Running: No
Slave_SQL_Running: No
*******************************
# ./slave_repl3307.sh
Critical slave is error
*********************************************************
Now Starting replication with Master Mysql!
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Now Replication is Finished!
**********************************************************
以上就是CentOS下编写shell脚本来监控MySQL主从复制的教程_MySQL的内容,更多相关内容请关注PHP中文网(www.php.cn)!
文章来源:http://www.php.cn/mysql-tutorials-50235.html
阅读全文
0 0
- CentOS下编写shell脚本来监控MySQL主从复制的教程_MySQL
- shell监控脚本实例—监控mysql主从复制
- Linux下MySQL主从同步监控shell脚本
- 自动监控主从MySQL同步的SHELL脚本
- 检测mysql主从复制是否正常的shell脚本
- 监控mysql主从一致性shell脚本
- mysql主从监控的脚本
- MySQL主从复制数据一致性校验shell脚本
- 【SHELL】监控Nginx运行,Mysql主从运行,主从复制延迟
- linux centos下mysql数据库的主从复制环境搭建
- linux centos下mysql数据库的主从复制环境搭建
- centos下搭建MySQL主从复制
- shell学习十四--编写监控mysql脚本
- CentOS Mysql主从复制
- shell监控MySQL主从状态脚本两则
- shell脚本监控mysql主从同步状态并自动修复
- nagios监控mysql主从复制
- 【nagios】监控mysql主从复制
- Maven Archetypes Part 2:怎样创建我的第一个jar?
- HLS协议详解
- 如何从零开始写一个即时通讯软件(附源码)
- 《reinforcement learning:an introduction》第五章《Monte Carlo Methods》总结
- 21-Vue单文件组件的使用方式介绍
- CentOS下编写shell脚本来监控MySQL主从复制的教程_MySQL
- JS中的运算符和表达式
- 异步fifo的设计(二)
- jQuery查找,获取和修改元素
- Load Data使用方法
- 接口的方法与变量
- mysql写存储过程的一些注意事项以及mysql的一些函数
- Eclipse安装Sequoyah插件 配置本机开发报错Native Development: Invalid path for NDK(路径无效) 解决方案
- Maven Archetypes Part 3: 怎样构建一个多模块工程?