我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL的slave_exec_mode参数说明及用处

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL的slave_exec_mode参数说明及用处

下面讲讲关于MySQL的slave_exec_mode参数说明及用处,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完MySQL的slave_exec_mode参数说明及用处这篇文章你一定会有所受益。

slave_exec_mode=IDEMPOTENT在MySQL复制环境中是个很有用的参数:只要在备机运行set global slave_exec_mode=IDEMPOTENT,备机的sql thread就运行在冥等模式下,可以让备机在insert主键、唯一键冲突,update、delete值未找到错误发生时不断开复制而保持冥等性(当即生效,连slave的sql线程都不用重启哟);而类似sql_slave_skip_counter=N和slave-skip-errors = N这样的粗暴跳过错误方法可能破坏主备一致性。

注意:使用冥等模式时表要有主键 

冥等模式并不是万能的,除了不能对DDL操作冥等,对字段长度不同导致的错误也不是冥等(譬如主机一个字段是char(20)而备机是char(10)),还有一个限制就是表有主键才会对insert的冥等设置有效:因为insert的冥等行为是通过主键来判断备机是否有重复值从而产生覆写操作,如果表没有主键,则备机即使设了冥等也可能会比主机多重复数据。

针对slave_exec_mode参数,它可以跳过1062和1032的错误,并且不影响同一个事务中正常的数据执行。如果是多个SQL组成的事务,则可以跳过有问题的event。

另外在GTID模式下的复制,sql_slave_skip_counter是不支持的,该模式下的复制可以自行测试。

MySQL的slave_exec_mode参数说明及用处

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

主从复制中1032错误一般是指要更改的数据不存在

遇到错误1032或者1062的处理方式:

所以处理该错误的方法有:

1:skip_slavesql_slave_skip_counter

stop slave;                                                                                                                                     Query OK, 0 rows affected (0.00 sec)

set global sql_slave_skip_counter=[1-4];

Query OK, 0 rows affected (0.00 sec)

start slave;

Query OK, 0 rows affected (0.00 sec)

2:在配置文件里指定slave-skip-errors=1062(需要重启)

这2种方法都能让复制恢复正常,但是会让主从数据不一致(谨慎使用),如果一个事务中多个语句,其他的语句也会丢失。

并且第2种方法还需要重启数据库,此时slave_exec_mode参数就派上用场了。在从库上设置该参数:

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

# slave上执行

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

stop slave;

start slave;

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

针对slave_exec_mode参数,它可以跳过1062和1032的错误,并且不影响同一个事务中正常的数据执行。如果是多个SQL组成的事务,则可以跳过有问题的event。

insert into x values(1),(4),(5); #其中从库有id=4这条记录

BEGIN;

INSERT INTO x SELECT 4;

DELETE FROM x WHERE id = 2; #从库没有这条记录

INSERT INTO x SELECT 5;

COMMIT;

#!/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@xxx.com

fi

对于以上MySQL的slave_exec_mode参数说明及用处相关内容,大家还有什么不明白的地方吗?或者想要了解更多相关,可以继续关注我们的行业资讯板块。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL的slave_exec_mode参数说明及用处

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

ThreadPoolExecutor参数的用法及说明

这篇文章主要介绍了ThreadPoolExecutor参数的用法及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-03-14

MySQL存储过程参数的用法及说明

目录mysql存储过程的参数输入参数输出参数输入输出参数(INOUT)MySQL存储过程的参数MySQL存储过程的参数共有三种:pythonINOUT INOUT输入参数输入参数(IN):在调用存储过程中传递数据给存储过程的参数(在
2022-08-17

keras.layers.Conv2D()函数参数用法及说明

这篇文章主要介绍了keras.layers.Conv2D()函数参数用法及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-02-21

MySQL之FIND_IN_SET()的用法及说明

目录一、语法二、用法三、用途举个例子一举个例子二总结一、语法FIND_IN_SET(str,strlist)str:要查询的字符串strList:一个被,号分隔开的字符串函数是返回strList中str所在的位置索引二、用法SELE
2023-01-06

MySQL窗口函数OVER()用法及说明

目录mysql窗口函数OVER()下面的讲解将基于这个employee2表MySQL窗口函数OVER()下面的讲解将基于这个employee2表mysql> SELECT * FROM employee2;+----+---------
2022-08-19

MySQL中with rollup的用法及说明

这篇文章主要介绍了MySQL中with rollup的用法及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

在fusionio上mysql几个参数的修改说明

在Fusion-io上修改MySQL的几个参数可以提高性能和优化数据库的运行。以下是几个常用参数的修改说明:1. innodb_io_capacity:这个参数指定了InnoDB存储引擎的I/O容量,即每秒可以处理的I/O请求数。对于Fus
2023-08-23

python print()函数的end参数和sep参数的用法说明

最近在学习python过程中,对print()打印输出函数进行了进一步学习。 python 2.6中,print输出内容需要使用引号。 python 3.0中的print 函数修改引号为括号,即print() print()函数打印输出默认
2022-06-02

mysql 的indexof函数用法说明

如下所示: LOCATE(substr,str) 返回子串substr在字符串str第一个出现的位置,如果substr不是在str里面,返回0.mysql> select LOCATE('bar', 'foobarbar'); -> 4 m
2022-05-24

python numpy.linalg.norm函数的使用及说明

这篇文章主要介绍了python numpy.linalg.norm函数的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-02-05

SQL函数Group_concat的用法及说明

目录SQL函数Group_concat的用法完整语法如下Group_concat函数长度问题解决的方式有三个总结SQL函数Group_concat的用法完整语法如下group_concat([DISTINCT] 要连接的字段 [Orde
2023-03-02

Vue中data传递函数、props接收函数及slot传参的使用及说明

这篇文章主要介绍了Vue中data传递函数、props接收函数及slot传参的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

编程热搜

目录