基于proxysql实现MySQL读写分离的实现实例

 更新时间:2025年11月11日 09:52:18   作者:yugi987838  
这篇文章主要介绍了基于proxysql实现MySQL读写分离,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

环境:

  • 系统版本:CentOS 7
  • MySQL版本:5.7.35

MySQL主从配置略过。

安装

# 安装
yum localinstall -y ./proxysql-2.2.0-1-centos7.x86_64.rpm
# 启动
systemctl start proxysql

配置

客户端口号: 6033。代理 mysql 服务的端口,也就是应用连接使用的

管理端口号: 6032。管理 proxysql配置 的端口,只能本地登录

# 1. 登录管理端
mysql -uadmin -padmin -h127.0.0.1 -P6032
# 2. 配置主从库
use main;
insert into mysql_servers(hostgroup_id,hostname,port,weight,comment) values(1,'192.168.0.10',3306,1,'master1');
insert into mysql_servers(hostgroup_id,hostname,port,weight,comment) values(2,'192.168.0.11',3306,1,'slave1');
# 2.2 检查添加结果
select * from main.mysql_servers;
# 2.3 加载配置到RUNTIME
load mysql servers to runtime;
# 2.4 写盘保存
save mysql servers to disk;
# 3. 配置proxysql客户端账户密码。
# 设置所有请求默认到hostgroupid为1的实例然后再根据路由分发
# transaction_persistent为1开启事务支持
insert into mysql_users(username,password,default_hostgroup,transaction_persistent)values('root','123456',1,1);
# 3.2 查询账户添加结果
select * from mysql_users;
# 3.3 保存
load mysql users to runtime;
save mysql users to disk;
# 4. 配置健康检测账号
# 4.1 登录后端master的mysql控制台
GRANT replication client ON *.* TO 'monitor'@'%' IDENTIFIED BY '123456';
flush privileges;
# 4.2 切换回proxy的控制台
set mysql-monitor_username='monitor';
set mysql-monitor_password='123456';
load mysql variables to runtime;
save mysql variables to disk;
# 5. 配置读写分离路由
# 将select语句全部路由至hostgroup_id=2的组,也就是从节点
# select * from tb for update这样的语句是修改数据的,所以需要单独定义,将它路由至hostgroup_id=1的组(也就是主节点)
# 其他没有被规则匹配到的组将会被路由至用户默认的组(mysql_users表中的default_hostgroup)
insert into mysql_query_rules(rule_id,active,match_digest,destination_hostgroup,apply)values(1,1,'^SELECT.*FOR UPDATE$',1,1);
insert into mysql_query_rules(rule_id,active,match_digest,destination_hostgroup,apply)values(2,1,'^SELECT',2,1);
load mysql query rules to runtime;
load admin variables to runtime;
save mysql query rules to disk;
save admin variables to disk;

测试读写分离

  1. 登录客户端
mysql -uroot -p'123456' -P6033 -h 127.0.0.1
# 随便执行点sql语句
  1. proxysql有个类似审计的功能,可以看到各类sql的执行情况。在proxysql管理端执行:
select * from stats.stats_mysql_query_digest;
-- 或者 select hostgroup,schemaname,digest_text,count_star,sum_time,min_time,max_time,sum_rows_affected,sum_rows_sent from stats.stats_mysql_query_digest;

其它

  • 修改proxysql后台处理MySQL流量的后台线程数。默认为4
set mysql-threads=16;
-- 查看
show variables like '%mysql-threads%';

到此这篇关于基于proxysql实现MySQL读写分离的文章就介绍到这了,更多相关MySQL proxysql读写分离内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • 简述MySQL InnoDB存储引擎

    简述MySQL InnoDB存储引擎

    这篇文章主要介绍了MySQL InnoDB存储引擎的相关资料,帮助大家更好的了解MySQL的存储引擎,感兴趣的朋友可以了解下
    2020-08-08
  • mysql数据库连接失败常见问题小结

    mysql数据库连接失败常见问题小结

    你有没有碰到过mysql数据库连接不上的问题呢?很多的小伙伴表示,经常会时不时的出现这些问题,下面这篇文章主要给大家介绍了关于mysql数据库连接失败常见问题的相关资料,需要的朋友可以参考下
    2023-06-06
  • Mysql查询优化之IN子查询优化方法详解

    Mysql查询优化之IN子查询优化方法详解

    项目中有需要,使用MySQL的in子查询,查询符合in子查询集合中条件的数据,但是没想到的是,MySQL的in子查询会如此的慢,让人无法接受,下面这篇文章主要给大家介绍了关于Mysql查询优化之IN子查询优化的相关资料,需要的朋友可以参考下
    2023-02-02
  • mysql 实现添加时间自动添加更新时间自动更新操作

    mysql 实现添加时间自动添加更新时间自动更新操作

    这篇文章主要介绍了mysql 实现添加时间自动添加更新时间自动更新操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • MySQL百万级数据大分页查询优化的实现

    MySQL百万级数据大分页查询优化的实现

    在数据库开发过程中我们经常会使用分页,但是如果是百万级数据呢,本文就详细的介绍一下MySQL百万级数据大分页查询优化的实现,感兴趣的可以了解一下
    2022-01-01
  • Mysql5.6修改root密码教程

    Mysql5.6修改root密码教程

    今天小编就为大家分享一篇关于Mysql5.6修改root密码教程,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-02-02
  • MySQL中把varchar类型转为date类型方法详解

    MySQL中把varchar类型转为date类型方法详解

    这篇文章主要介绍了MySQL中把varchar类型转为date类型方法详解的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • CentOS7.5 安装MySql的教程

    CentOS7.5 安装MySql的教程

    这篇文章主要介绍了CentOS7.5 安装MySql的教程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • Mysql 切换数据存储目录的实现方法

    Mysql 切换数据存储目录的实现方法

    这篇文章主要介绍了Mysql 切换数据存储目录的实现方法的相关资料,需要的朋友可以参考下
    2017-07-07
  • 清空mysql 查询缓存的可行方法

    清空mysql 查询缓存的可行方法

    mysql对同一条sql进行了缓存,在第二次运行时, 瞬间就完成了,若要清除缓存,可通过下面的方法来实现
    2014-07-07

最新评论