mysql excu()_MySQL的slave_exec_mode参数作用

主从复制中常会遇到的问题就是1062主键重复

如果在读写分离的架构中,slave同步失败会对业务造成很大的影响的

因此,很有必要对主从复制做些监控,做些自动化的处理。涉及到MySQL的一个参数slave_exec_mode

slave_exec_mode参数可用来自动处理同步复制错误:

# slave上执行

> set global slave_exec_mode='IDEMPOTENT';  幂等模式 (默认是STRICT严格模式)

> stop slave;

> start slave;

经过上面设置后,1062错误(主键重复)时,就会自动跳过错误,并且记录到错误日志里。

其实,slave_exec_mode和slave_skip_errors的作用是一样的,但是slave_skip_errors不支持动态修改,必须重启mysql才能生效,因此建议使用slave_exec_mode。

脚本方法如下 cat /home/scripts/manage_repl.sh:

#!/bin/bash

# Description: 自动跳过主从复制的错误(错误代码1023、1062) ,这个脚本在slave上执行

#

user='root'

pass='root'

port='3306'

IP='172.16.10.12'

MYSQLCLI='/usr/local/mysql/bin/mysql'

STATUS=$($MYSQLCLI -u$user -p$pass -h $IP -e 'show slave status\G'|sed -n '13p'|awk -F ":" '{print $2}')

if [[ $STATUS != 'YES' ]];then

$MYSQLCLI -u$user -p$pass -h $IP -e "SET GLOBAL slave_exec_mode='IDEMPOTENT';"

$MYSQLCLI -u$user -p$pass -h $IP -e "stop slave';"

$MYSQLCLI -u$user -p$pass -h $IP -e "start slave';"

echo -e "地址: $IP\n端口: 3306\n服务: MySQL主从复制发生错误,系统已自动跳过错误,请后续跟进处理。\n发生时间: `date +"%F %T"`" \

| mail -s '主从复制错误警告'  xxxxxx@126.com

fi

添加一个每隔10分钟检查一次主从复制状态的计划任务,如下:

echo '*/10 * * * * /home/scripts/manage_repl.sh' >>/var/spool/cron/root

转载于:http://www.iyunv.com/thread-236258-1-1.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值