MySQL运维实战(7.2) MySQL复制server_id相关问题

news/2024/7/23 8:47:55 标签: mysql, 运维, adb

作者:俊达

主库server_id没有设置

主库没有设置server_id

Got fatal error 1236 from master when reading data from binary log: 'Misconfigured master - server_id was not set'

主库查看server_id

mysql> show variables like 'server_id';
+----------------+-------+
| Variable_name  | Value |
+----------------+-------+
| server_id      | 1     |

即使没有设置server_id,show variables命令查看server_id为1,

解决办法:
1、 主库设置server_id
建议不要将server_id设置为1

mysql> set global server_id=234;

同时在配置文件中设置server_id,避免数据库重启后参数设置失效。
2、备库上重新启动复制

stop slave;
start slave;
show slave status\G

备库server_id没有设置

如果备库没有设置server_id,也无法启动复制

mysql> set global server_id=default;
Query OK, 0 rows affected (0.00 sec)

mysql> start slave;
ERROR 1200 (HY000): The server is not configured as slave; fix in config file or with CHANGE MASTER TO

从错误日志中可以看到无法启动备库的原因:

2023-06-12 16:36:15 18518 [ERROR] Server id not set, will not start slave

解决方法:设置server_id,同时在配置文件中加入server_id配置。

mysql> set global server_id=236;
Query OK, 0 rows affected (0.00 sec)

mysql> start slave;
Query OK, 0 rows affected (0.00 sec)

主备库server_id相同

主备库server_id相同

Fatal error: The slave I/O thread stops because master and slave have equal MySQL server ids; these ids must be different for replication to work (or the --replicate-same-server-id option must be used on slave but this does not always make sense; please check the manual before using it).

解决方法:
设备库将server_id设置成不一样。

server_id重复导致的问题

mysql复制关系中,主库和备库的server_id如果相同,IO线程会直接报错中断。但是在级联复制的架构下,肯能会出现server_id相同的问题。
在这里插入图片描述
如上图的例子中,主和备1的server_id不同,备2和备1的server_id也不同,但是备2和备1的server_id相同,这会导致一个问题:备2的IO线程从备1获取binlog事件时,发现事件的server_id和自己的server_id一样,就会忽略这些事件,从而备2缺少数据。这种情况下,备2不会产生任何异常日志。show slave status查看seconds_behind_master可能也没有问题。

级联复制修改复制架构导致的问题

级联复制架构下,修改复制架构时操作不当,可能会引起binlog事件无限循环复制的问题。下面是一个例子:
原先的复制结构如下:
在这里插入图片描述
当前主库为主,由于某个原因,需要下线主,备1和备2组成新的双向复制架构:
在这里插入图片描述
执行的操作如下:
1、备1上执行stop slave;
2、备2上执行show master status,查看当前binlog位点
3、备1上执行change master to备2,指向步骤2获取到的binlog位点。

如果执行上述的第2步的时候,备2上有延迟,那么获取到的位点之后,可能还会产生server_id为100的binlog事件(从备1上复制过来的,来源于主的事物),当备1复制指向备2时,这些server_id为100的事件,就可能会一直循环执行。具体是否会循环执行,还依赖于binlog格式以及具体的事件。
在row模式下,如果是insert事件,且涉及的表无主键和唯一约束,insert会一直循环执行。
在statement模式下,如果是update语句(update t set c = c + 1),则该update语句会一直循环执行。

复制架构中存在环路的情况下,修改server_id也可能会产生类似的问题。
这类问题需要从源头上避免:
1、保证server_id全局唯一。
2、不随意修改server_id。
3、修改复制架构时,如果备库存在延迟,需要特别注意。
4、开启GTID。如果开启了GTID,则不会重复执行事务。

更多技术信息请查看云掣官网https://yunche.pro/?t=yrgw


http://www.niftyadmin.cn/n/5392181.html

相关文章

PSE gPROMS Suite 2023 x64 +ModelBuilder_7.1.1

gPROMS (generalprocess modelling system) 起源于英国帝国理工大学的过程系统工程学院,历经数十年的过程系统研发,以算法封装的形式开发出gPROMS,于1997年成立了PSE公司 (Process System Enterprise Ltd.)负责gPROMS全部商业运营。2006年推出…

物奇ENC算法开关接口修改方法

物奇ENC算法开关接口修改 是否需要申请加入数字音频系统研究开发交流答疑群(课题组)?可加我微信hezkz17, 本群提供音频技术答疑服务,群赠送语音信号处理降噪算法,蓝牙耳机音频,DSP音频项目核心开发资料, 1 配置工具事件接口 2 代…

golang实现一个BasicAuth的HTTP server

之前写的《golang实现一个简单的HTTP server》没有包含认证部分 本例给出了支持BasicAuth的实现,以及如何在一个项目中导入自己定义的package 编写代码 创建项目所在文件夹 adminhpc-1:~/go$ mkdir auth_http adminhpc-1:~/go$ cd auth_http adminhpc-1:~/go/auth…

自动化部署证书 acme.sh 使用教程

简介 acme.sh 是一个开源的 ACME 协议的客户端工具,用于自动化申请、更新和部署 SSL/TLS 证书。通过使用 acme.sh,用户可以轻松地在服务器上设置 HTTPS 加密连接,而无需手动操作。它支持多种 DNS 接口和证书颁发机构,可以与各种 …

【MySQL面试复习】并发事务带来了哪些问题?如何解决?

系列文章目录 在MySQL中,如何定位慢查询? 发现了某个SQL语句执行很慢,如何进行分析? 了解过索引吗?(索引的底层原理)/B 树和B树的区别是什么? 什么是聚簇索引(聚集索引)和非聚簇索引…

【计算机网络】深度学习使用应用层的HTTP协议

💓 博客主页:从零开始的-CodeNinja之路 ⏩ 收录文章:【计算机网络】深度学习使用应用层的HTTP协议 🎉欢迎大家点赞👍评论📝收藏⭐文章 文章目录 一:HTTP是什么二:HTTP请求1.HTTP请求的组成2.HTTP请求的方法…

力扣:93. 复原 IP 地址

回溯: 1.先定义一个接收的集合,之后再定义一个记录小数点的变量。之后编写回溯函数,终止条件为小数点的个数为3时,同时要判断最后一段的组合的值是否属于ip地址的范围。之后再用for循环来遍历ip地址的组合,先判断组合…

python print 格式化输出详解

print 输出字符串和数字 以下实例中列举了print打印各种类型的示例 示例如下, print("qayrup") # 直接输出字符串print(100) # 输出数字str qayrup print(str) # 输出变量L [1,2,a] # 输出列表类型变量 print(L) t (1,2,a…