MySQL主从复制如何实现读写分离_利用ProxySQL进行流量分发

ProxySQL 启动后连不上 MySQL 主从集群,需检查 mysql_servers 表的 hostgroup_id(主库设为0、从库设为1)、status(均为'ONLINE')、weight、max_replication_lag 及 monitor 用户权限,并执行 LOAD/SAVE 操作生效配置。ProxySQL 启动后连不上 MySQL 主从集群?检查 mysql_servers 表的 hostgroup_id 和状态ProxySQL 不会自动识别主从角色,它只按你配置的 hostgroup_id 分发流量。常见错误是把主库和从库都塞进同一个 hostgroup_id,结果读请求打到主库、写请求也打到从库------根本没分离。实操建议:主库必须配置在 hostgroup_id = 0(默认写组),status = 'ONLINE',且 weight 设得足够高(比如 1000)从库统一配在 hostgroup_id = 1(默认读组),status = 'ONLINE',weight 可设为 100 或按负载调整务必执行 LOAD MYSQL SERVERS TO RUNTIME 和 SAVE MYSQL SERVERS TO DISK,否则配置不生效用 SELECT * FROM mysql_servers 确认 max_replication_lag 是否设为合理值(如 30),否则延迟大的从库仍会被选中读写分离规则没生效?重点查 mysql_query_rules 的 match_digest 和 destination_hostgroupProxySQL 靠正则或 digest 匹配 SQL 来决定路由,不是靠语法解析。很多用户以为 SELECT 开头就走读组,结果发现 SELECT FOR UPDATE 也被发到从库------因为规则里只写了 ^SELECT,没排除带锁的语句。实操建议:写规则优先匹配明确的写操作:match_digest = '^INSERT ' | '^UPDATE ' | '^DELETE ' | '^REPLACE ' → destination_hostgroup = 0读规则要排除干扰:match_digest = '^SELECT ' | '^WITH ' → destination_hostgroup = 1,但必须加 negate_match_pattern = 1 并另配一条规则拦截 SELECT.*FOR UPDATE 回写组apply = 1 必须设对,否则规则不启用;sticky_conn = 1 在事务中可避免主从切换导致的报错规则顺序很重要:ProxySQL 从上到下匹配,写规则必须排在读规则前面应用连 ProxySQL 后出现 ERROR 9001 (HY000): Max connect timeout reached while reaching hostgroup 1这不是网络不通,而是 ProxySQL 尝试连接从库时超时,通常因为从库不可达、MySQL 用户权限不足,或从库启用了 skip_networking。 幻导航网 发现优质实用网站,开启网络探索之旅!

相关推荐
AI人工智能+电脑小能手6 小时前
【大白话说Java面试题 第87题】【Mysql篇】第17题:分布式事务的实现原理?
java·数据库·分布式·mysql·面试
yyuuuzz6 小时前
独立站的技术基础与常见运维问题
大数据·运维·服务器·网络·数据库·aws
心中有国也有家7 小时前
GE图引擎深度解析——CANN的计算图优化与执行引擎
人工智能·pytorch·python·学习·numpy
卷毛的技术笔记8 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)
java·人工智能·后端·python·spring·ai编程
编程大师哥8 小时前
匿名函数 lambda + 高阶函数
java·python·算法
vb2008118 小时前
FastAPI APIRouter
开发语言·python
adrninistrat0r8 小时前
Java调用链MCP分析工具
java·python·ai编程
杨充9 小时前
1.3 浮点型数据设计灵魂
开发语言·python·算法
meilindehuzi_a9 小时前
深入浅出数据结构:Python 字典(Dict)与集合(Set)的哈希表底层全链路追踪
数据结构·python·散列表
Lucas凉皮9 小时前
20243408 2025-2026-2 《Python程序设计》综合实践报告
python·实验报告