MySQL主从故障排查思路

一.确认主从状态


首先要确定主从复制的状态,可以通过执行以下命令来检查:

1)SHOW MASTER STATUS; 命令用于显示主库的状态信息,包括以下列:

  • File: 当前正在写入的二进制日志文件名。

  • Position: 文件中当前正在写入的位置。

  • Binlog_Do_DB: 主库正在复制的数据库列表。

  • Binlog_Ignore_DB: 主库正在忽略复制的数据库列表。

2)SHOW SLAVE STATUS; 命令用于显示从库的状态信息,包括以下列:

  • Slave_IO_State: 从库的 I/O 线程的当前状态。

  • Master_Host: 主库的主机名或 IP 地址。

  • Master_User: 从库用于连接主库的用户名。

  • Master_Port: 主库的端口号。

  • Connect_Retry: 从库尝试连接到主库的次数。

  • Master_Log_File: 主库当前正在写入的二进制日志文件名。

  • Read_Master_Log_Pos: 从库当前读取的主库二进制日志位置。

  • Relay_Log_File: 从库正在写入的中继日志文件名。

  • Relay_Log_Pos: 从库当前写入的中继日志位置。

  • Relay_Master_Log_File: 从库当前读取的主库二进制日志文件名。

  • Slave_IO_Running: 从库的 I/O 线程是否正在运行。

  • Slave_SQL_Running: 从库的 SQL 线程是否正在运行。

  • Last_Errno: 最后一个复制错误的错误码。

  • Last_Error: 最后一个复制错误的错误信息。

  • Seconds_Behind_Master: 从库与主库之间的复制延迟时间(秒)。

这些信息可以帮助确定主从复制的状态,检查复制是否正常运行以及是否存在任何错误或延迟。

二.检查网络连接


检查主库和从库之间的网络连接是否正常 ,可以使用 ping 命令或 telnet 命令来测试主从服务器之间的连通性。

  • ping 主库IP地址。

  • telnet 主库IP地址 3306。

如果网络连接正常,可以继续排查其他可能的问题。

三.检查主库状态


在主库上执行以下命令来检查主库的状态:

1) SHOW PROCESSLIST; 命令用于显示当前正在运行的 MySQL 进程列表,包括以下列:

  • Id: 进程的唯一标识符。

  • User: 进程所属的用户。

  • Host: 进程连接的主机名或 IP 地址。

  • db: 进程正在使用的数据库。

  • Command: 进程正在执行的命令类型。

  • Time: 进程运行的时间(秒)。

  • State: 进程的当前状态。

  • Info: 进程正在执行的具体 SQL 语句。

这些信息可以帮助确定当前正在运行的查询、连接和执行时间,以及进程的状态。

2 )SHOW ENGINE INNODB STATUS; 命令用于显示 InnoDB 存储引擎的状态信息

它提供了一个详细的报告,包含以下部分:

  • SEMAPHORES: 信号量的状态信息。

  • TRANSACTIONS: 事务的状态信息。

  • FILE I/O: 文件 I/O 操作的状态信息。

  • INSERT BUFFER AND ADAPTIVE HASH INDEX: 插入缓冲区和自适应哈希索引的状态信息。

  • LOG: 日志的状态信息。

  • BUFFER POOL AND MEMORY: 缓冲池和内存的状态信息。

  • ROW OPERATIONS: 行操作的状态信息。

  • SEMAPHORES: 信号量的状态信息。

  • TRANSACTIONS: 事务的状态信息。

  • FILE I/O: 文件 I/O 操作的状态信息。

  • INSERT BUFFER AND ADAPTIVE HASH INDEX: 插入缓冲区和自适应哈希索引的状态信息。

  • LOG: 日志的状态信息。

  • BUFFER POOL AND MEMORY: 缓冲池和内存的状态信息。

  • ROW OPERATIONS: 行操作的状态信息。

  • TRANSACTIONS: 事务的状态信息。

  • FILE I/O: 文件 I/O 操作的状态信息。

  • INSERT BUFFER AND ADAPTIVE HASH INDEX: 插入缓冲区和自适应哈希索引的状态信息。

  • LOG: 日志的状态信息。

  • BUFFER POOL AND MEMORY: 缓冲池和内存的状态信息。

  • ROW OPERATIONS: 行操作的状态信息。

这些信息可以用于分析和诊断 InnoDB 存储引擎的性能和问题。

四.检查从库状态


在从库上执行以下命令来检查从库的状态:

复制代码
SHOW SLAVE STATUS;

检查 Seconds_Behind_Master 的值,如果该值为 0,则表示从库与主库同步正常。如果该值不为 0,则表示从库与主库之间存在延迟。

五.检查错误日志


检查主库和从库的错误日志,查看是否有任何错误或警告信息。

可以通过执行以下命令来查看错误日志的位置:

复制代码
SHOW VARIABLES LIKE 'log_error';

然后,使用文本编辑器打开错误日志文件,查找其中的错误或警告信息。

重启主从服务:如果以上步骤没有找到问题,可以尝试重启主从服务。首先停止从库的复制进程,然后停止主库的 MySQL 服务,最后按照正确的顺序启动主从服务。

复制代码
STOP SLAVE;
STOP MASTER;
START MASTER;
START SLAVE;

重启服务后,再次检查主从状态和复制日志,确保复制正常。

数据一致性检查:如果主从复制仍然存在问题,可以执行数据一致性检查。可以使用 Percona Toolkit 或其他工具来比较主库和从库之间的数据差异,并尝试修复数据不一致的问题。

基本上MySQL 主从故障排查就这些了。根据具体情况,可能需要进行更多的排查步骤或使用其他工具来解决问题。

相关推荐
倒流时光三十年1 分钟前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
码农小卡拉24 分钟前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
怣5028 分钟前
MySQL多表连接:全外连接、交叉连接与结果集合并详解
数据库·sql
wjhx1 小时前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt
冰暮流星1 小时前
javascript之二重循环练习
开发语言·javascript·数据库
万岳科技系统开发1 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
冉冰学姐2 小时前
SSM智慧社区管理系统jby69(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·管理系统·智慧社区·ssm 框架
杨超越luckly2 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强
斯普信专业组2 小时前
构建基于MCP的MySQL智能运维平台:从开源服务端到交互式AI助手
运维·mysql·开源·mcp
Elastic 中国社区官方博客2 小时前
Elasticsearch:Workflows 介绍 - 9.3
大数据·数据库·人工智能·elasticsearch·ai·全文检索