简化版 ProxySQL 双主读写分离配置
以下是更简单的 ProxySQL 双主读写分离配置步骤:
1. 基本配置(只需执行这些命令)
-- 添加服务器(假设两个主库IP为192.168.1.101和192.168.1.102)
INSERT INTO mysql_servers(hostgroup_id, hostname, port) VALUES
(10, '192.168.1.101', 3306),
(10, '192.168.1.102', 3306),
(20, '192.168.1.101', 3306),
(20, '192.168.1.102', 3306);
-- 设置监控账号(先在MySQL创建好这个用户)
UPDATE global_variables SET variable_value='monitor' WHERE variable_name='mysql-monitor_username';
UPDATE global_variables SET variable_value='monitor_password' WHERE variable_name='mysql-monitor_password';
-- 添加应用用户
INSERT INTO mysql_users(username, password, default_hostgroup) VALUES ('app_user', 'app_password', 10);
-- 简单读写分离规则
INSERT INTO mysql_query_rules (rule_id, active, match_pattern, destination_hostgroup, apply) VALUES
(1, 1, '^SELECT.*FOR UPDATE', 10, 1), -- SELECT FOR UPDATE去写组
(2, 1, '^INSERT', 10,- ^UPDATE', 10,- ^DELETE', 10,- ^SELECT .*INTO OUTFILE ',10 ,- ^SELECT .*INTO DUMPFILE ',10 ,- ^SELECT ', 20 , - SELECT去读组
--使所有配置生效
LOAD MYSQL SERVERS TO RUNTIME;
LOAD MYSQL USERS TO RUNTIME;
LOAD MYSQL QUERY RULES TO RUNTIME;
SAVE MYSQL SERVERS TO DISK;
SAVE MYSQL USERS TO DISK;
SAVE MYSQL QUERY RULES TO DISK;
##2 .验证是否工作
#测试写操作(应该路由到hostgroup=10)
mysql-u app_user-papp_password-h proxysql_ip-P6033-e"CREATE TABLE test.t(id int);"
#测试读操作(应该路由到hostgroup=20)
mysql-u app_user-papp_password-h proxysql_ip-P6033-e"SELECT * FROM test.t;"
##3 .查看路由情况
--查看查询被路由到了哪个组
SELECT hostgroup hg ,sum_time ,count_star ,digest_text FROM stats_mysql_query_digest ORDER BY sum_time DESC;
--查看服务器状态
SELECT * FROM runtime_mysql_servers;
这样就完成了最基本的双主读写分离配置。如果需要更复杂的负载均衡策略或故障转移,可以在此基础上进行扩展。
内容由零声教学AI助手提供,问题来源于学员提问