proxysql实现mysql主从的读写分离

本文详细介绍如何在CentOS 7环境下安装并配置ProxySQL中间件,包括安装过程、添加MySQL节点、配置监控用户、设置SQL执行用户、创建路由规则等关键步骤。通过此教程,读者将能掌握ProxySQL的基本使用方法。

文章目录

在这里插入图片描述
安装proxysql

proxysql

yum install proxysql-1.4.16-1-centos7.x86_64.rpm mariadb -y
service proxysql start
mysql -uadmin -padmin -P6032 -h127.0.0.1
MySQL [(none)]> select * from sqlite_master where name='mysql_servers'\G  查看表结构

向ProxySQL中添加MySQL节点
proxysql

MySQL [(none)]> insert into mysql_servers(hostgroup_id,hostname,port) values(20,'192.168.43.17',3306);
MySQL [(none)]> insert into mysql_servers(hostgroup_id,hostname,port) values(10,'192.168.43.7',3306);
MySQL [(none)]> load mysql servers to runtime;
MySQL [(none)]> save mysql servers to disk;

添加监控后端节点的用户
master

MariaDB [(none)]> grant replication client on *.* to monitor@'192.168.43.%' identified by 'monitor';

ProxySQL上配置监控用户
proxysql

MySQL [(none)]> set mysql-monitor_username='monitor';
MySQL [(none)]> set mysql-monitor_password='monitor';
MySQL [(none)]> load mysql variables to runtime;
MySQL [(none)]> save mysql variables to disk;

监控模块的指标保存在monitor库的log表中
查看监控连接是否正常的 (对connect指标的监控):(如果connect_error的结果为NULL则表示正常)
proxysql

MySQL [(none)]> select * from mysql_server_connect_log;

测试后端服务器是否正常
proxysql

MySQL> select * from mysql_server_ping_log;

查看read_only和replication_lag的监控日志
proxysql

MySQL> select * from mysql_server_read_only_log;
MySQL> select * from mysql_server_replication_lag_log;

分组信息
proxysql

MySQL [(none)]> insert into mysql_replication_hostgroups values(10,20,"test");
MySQL [(none)]> load mysql servers to runtime;
MySQL [(none)]> save mysql servers to disk;
MySQL [(none)]> select hostgroup_id,hostname,port,status,weight from mysql_servers;

配置发送SQL语句的用户
master

MariaDB [(none)]> grant all on *.* to sqluser@'192.168.43.%' identified by 'sqluser'; 

proxysql

MySQL [(none)]> insert into mysql_users(username,password,default_hostgroup)values('sqluser','sqluser',10);
MySQL [(none)]> load mysql users to runtime;
MySQL [(none)]> save mysql users to disk;

创建路由规则
proxysql

MySQL [(none)]> insert into mysql_query_rules (rule_id,active,match_digest,destination_hostgroup,apply)values(1,1,'^SELECT.*FOR UPDATE$',10,1),(2,1,'^SELECT',20,1);
MySQL [(none)]> load mysql query rules to runtime;
MySQL [(none)]> save mysql query rules to disk;
MySQL [(none)]> select rule_id,active,match_digest,destination_hostgroup,apply from mysql_query_rules;

客户端测试
client

yum install mysql -y
mysql -usqluser -psqluser -h192.168.43.27 -P6033 -e "create table t1(id int)" db1

查看路由信息
proxysql

MySQL [(none)]> SELECT hostgroup hg,sum_time, count_star, digest_text FROM stats_mysql_query_digest ORDER BY sum_time DESC;

在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值