Seconds_Behind_Master为NULL说明主从同步链路中断,常见原因有主库未启用binlog、从库CHANGE MASTER TO参数错误、网络或复制账号权限问题。主从复制没跑通,SHOW SLAVE STATUS 里 Seconds_Behind_Master 一直是 NULL说明从库根本没连上主库,不是延迟问题,是同步链路断了。常见原因有三个:一是主库没开 binlog(检查 my.cnf 里有没有 log-bin=mysql-bin 和 server-id);二是从库执行过 CHANGE MASTER TO 但主库的 master_log_file 或 master_log_pos 填错了,尤其容易把主库 SHOW MASTER STATUS 的结果抄错位;三是网络或权限问题------从库用的复制账号(比如 repl@'%' )必须有 REPLICATION SLAVE 权限,且主库防火墙要放行 3306 端口。读写分离中间件选 ProxySQL 还是 MaxScale?ProxySQL 更轻量、配置灵活,适合中小流量和需要 SQL 改写(比如自动把 SELECT 路由到从库)的场景;MaxScale 对 MySQL 协议解析更严谨,自带监控面板,但资源占用高,升级路径稍复杂。两者都支持权重轮询和故障自动摘除,但注意:-- ProxySQL 的路由规则靠 mysql_query_rules 表维护,改完要 LOAD MYSQL QUERY RULES TO RUNTIME 才生效;-- MaxScale 的 readwritesplit 模块默认不转发事务内的 SELECT,避免从库读到未提交数据,这点容易被忽略;-- 无论用哪个,应用层都别依赖"刚写完立刻能读到",因为主从复制有天然延迟。从库执行 SELECT 报错 ERROR 1236 (HY000): Could not find first log file name in binary log index file这是典型的 binlog 文件被主库清理了,但从库还没来得及拉取完。主库的 expire_logs_days 设太小(比如默认 0 或 3 天),而从库因网络抖动、大事务阻塞等原因 lag 时间超过保留窗口,就会触发这个错误。解决方法只有两个:-- 立即停掉从库,用 mysqldump + --master-data=2 重新搭建从库(最稳妥);-- 或者临时调大主库 expire_logs_days,再手动找一个从库还能追上的 binlog 位置(查 SHOW BINARY LOGS 和从库 Relay_Master_Log_File),但风险高,不推荐线上用。 Murf AI AI文本转语音生成工具
相关推荐
m0_741173331 小时前
HTML5中WebSocket在弱网环境下的延迟抖动算法补偿l1t1 小时前
astral-sh发布的musl和gnu版本standalone python 性能比较2401_871492851 小时前
Pandas如何做时间差对齐_pd.merge_asof按最近的时间戳合并两表sg_knight1 小时前
Python 设计模式:迭代器模式——用优雅的方式遍历一切阿豪只会阿巴2 小时前
【没事学点啥】TurboBlog轻量级个人博客项目——Turbo Blog 项目学习与上线指南m0_716255002 小时前
第一部分 数据开发 面试全题 模拟口述版(自问自答)L-影2 小时前
常见的 ORM 工具噢,我明白了2 小时前
MySQL常用指令--标准的电商/后台管理系统基础结构飞Link2 小时前
构筑你的数字第二大脑:Obsidian 深度解析与配置指南