【MySQL从节点异常断连后的Slave_SQL_Running 处于Connecting的解决方案】

MySQL从节点异常断连后的Slave_SQL_Running 处于Connecting的解决方案

问题背景

MySQL 从节点在断连后重连时出现 "IO Connecting" 状态,Last_IO_Error 2061,说明 I/O 线程无法成功连接主库进行认证。这通常发生在 MySQL 8.0+ 主库 + 未启用 SSL 的复制连接场景中,具体抛错及日志信息如下:

问题原因

主库用户使用了 caching_sha2_password 插件(MySQL 8.0 默认)且从库尝试以非加密(明文)方式连接后被拒绝了,抛出 IO_Error 2061,当从库断连后重试仍使用旧的配置,导致连接失败,IO处在 "Connecting"中。

解决方案:从节点复制时启用 SSL

步骤1: 确认主库已启用 SSL,返回为YES,代表已启用,一般MySQL8.0默认开始SSL。

复制代码
 SHOW VARIABLES LIKE 'have_ssl';

如果主库没有启用SSL,可以开启SSL,配置如下,在my.cnf配置文件中增加如下语句,并重启MySQL实例。

复制代码
[mysqld]
ssl-ca=/path/to/ca.pem
ssl-cert=/path/to/server-cert.pem
ssl-key=/path/to/server-key.pem

步骤 2: 修改复制用户,强制使用 SSL。

复制代码
ALTER USER 'slave'@'%' IDENTIFIED BY 'StrongPass123!' REQUIRE SSL;


步骤 3: 在从库配置 CHANGE MASTER 启用 SSL,查看从节点连接slave_IO_connecting 未YES。

复制代码
STOP SLAVE;

CHANGE MASTER TO
  MASTER_HOST='主库IP',
  MASTER_USER='slave',
  MASTER_PASSWORD='密码',
  MASTER_SSL=1,
  MASTER_SSL_CA='/etc/mysql/certs/ca.pem',  //证书文件可选择性添加
  MASTER_LOG_FILE='mysql-bin.000006',
  MASTER_LOG_POS=649;

START SLAVE;
相关推荐
曾几何时`3 小时前
MySQL(七)索引
数据库·mysql
悠悠121383 小时前
一条 SQL 从敲下回车,到在 MySQL 里“跑完一生”,中间到底经历了啥?
数据库·sql·mysql
秋93 小时前
MySQL 9.7.0 使用详解:新特性、实战与避坑指南
android·数据库·mysql
狼与自由3 小时前
clickhouse ReplacingMergeTree
android·clickhouse
吉吉613 小时前
php反序列化基础知识前奏
android·php·反序列化
山峰哥4 小时前
SQL优化从入门到精通:20个案例破解性能密码
数据库·sql·oracle·性能优化·深度优先
努力努力再努力wz4 小时前
【MySQL进阶系列】拒绝冗余SQL:带你透彻理解视图的底层逻辑
android·c语言·数据结构·数据库·c++·sql·mysql
历程里程碑4 小时前
MySQL数据类型全解析 + 代码实操讲解
大数据·开发语言·数据库·sql·mysql·elasticsearch·搜索引擎
杨云龙UP4 小时前
Windows Server 2012 环境下 Oracle 11.2 使用 expdp 实现自动备份、异地复制与定期清理_20260504
服务器·数据库·windows·mysql·docker·oracle·容器
nbwenren4 小时前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb