mysql如何通过主从备份实现读写分离_配置mysql架构模式

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文本转语音生成工具

相关推荐
智慧物业老杨1 分钟前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
橙橙笔记13 分钟前
Python的学习第一部分
python·学习
TheRouter37 分钟前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现
数据库·人工智能·oracle
Omics Pro1 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort1 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
biter down1 小时前
基于 Pywinauto 的 QQ 音乐 GUI 自动化测试实践
python
人道领域2 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
JAVA面经实录9172 小时前
Hibernate面试题库
数据库·oracle·hibernate
迷枫7122 小时前
DM8 目录结构与常用排查入口梳理
服务器·数据库
EntyIU3 小时前
mineru从安装部署到测试使用完整指南
python·ocr