MySQL中间件proxysql

ProxySQL是一款开源的MySQL中间件,支持读写分离、SQL路由等功能。本文介绍了ProxySQL的基本概念、安装过程、Admin管理接口及其相关变量,详细阐述了如何管理和配置ProxySQL,包括监控后端节点、多层配置系统以及启动过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


1. 概述


什么是proxysql?

  • ProxySQL 是基于 MySQL 的一款开源的中间件的产品,是一个灵活的 MySQL 代理层,可以实现读写分离,支持 Query 路由功能,支持动态指定某个 SQL 进行缓存,支持动态加载(无需重启 ProxySQL 服务),故障切换和一些 SQL 的过滤功能
  • ProxySQL有官方版和 percona 版两种。percona版是在官方版的基础上修改的,添加了几个比较实用的工具。生产环境建议用官方版

proxysql有哪些功能?

  • 最基本的读/写分离,且方式有多种
  • 可定制基于用户、基于schema、基于语句的规则对SQL语句进行路由。换句话说,规则很灵活。基于schema和与语句级的规则,可以实现简单的sharding(分库分表)
  • 可缓存查询结果。虽然ProxySQL的缓存策略比较简陋,但实现了基本的缓存功能,绝大多数时候也够用了。此外,作者已经打算实现更丰富的缓存策略
  • 监控后端节点。ProxySQL可以监控后端节点的多个指标,包括:ProxySQL和后端的心跳信息,后端节点的read-only/read-write,slave和master的数据同步延迟性(replication lag)

2. 安装proxysql

//下载proxysql安装包
[root@node2 ~]# wget http://repo.proxysql.com/ProxySQL/proxysql-2.0.x/centos/7/proxysql-2.0.13-1-centos7.x86_64.rpm
[root@node2 ~]# yum -y install localinstall proxysql-2.0.13-1-centos7.x86_64.rpm

//启动proxysql
[root@node2 ~]# systemctl start proxysql
[root@node2 ~]# ss -antl |grep -E '6032|6033'
LISTEN     0      128          *:6032                     *:*                  
LISTEN     0      128          *:6033                     *:*                  
LISTEN     0      128          *:6033                     *:*                  
LISTEN     0      128          *:6033                     *:*                  
LISTEN     0      128          *:6033                     *:*

3. ProxySQL的Admin管理接口


当 ProxySQL 启动后,将监听两个端口:

  • admin管理接口,默认端口为6032。该端口用于查看、配置ProxySQL
  • 接收SQL语句的接口,默认端口为6033,这个接口类似于MySQL的3306端口

在这里插入图片描述
ProxySQL 的 admin 管理接口是一个使用 MySQL 协议的接口,所以,可以直接使用 mysql 客户端、navicat 等工具去连接这个管理接口,其默认的用户名和密码均为 admin

[root@node2 ~]# mysql -uadmin -padmin -h127.0.0.1 -P6032
MySQL [(none)]> show databases;
+-----+---------------+-------------------------------------+
| seq | name          | file                                |
+-----+---------------+-------------------------------------+
| 0   | main          |                                     |
| 2   | disk          | /var/lib/proxysql/proxysql.db       |
| 3   | stats         |                                     |
| 4   | monitor       |                                     |
| 5   | stats_history | /var/lib/proxysql/proxysql_stats.db |
+-----+---------------+-------------------------------------+
5 rows in set (0.00 sec)

main:内存配置数据库,即 MEMORY,表里存放后端 db 实例、用户验证、路由规则等信息
disk:持久化的磁盘的配置 
stats:统计信息的汇总 
monitor:一些监控的收集信息,比如数据库的健康状态等 
stats_history:这个库是 ProxySQL 收集的有关其内部功能的历史指标

由于 ProxySQL 的配置全部保存在几个自带的库中,所以通过管理接口,可以非常方便地通过发送一些SQL命令去修改 ProxySQL 的配置。 ProxySQL 会解析通过该接口发送的某些对ProxySQL 有效的特定命令,并将其合理转换后发送给内嵌的 SQLite3 数据库引擎去运行

ProxySQL 的配置几乎都是通过管理接口来操作的,通过 Admin 管理接口,可以在线修改几乎所有的配置并使其生效。只有两个变量的配置是必须重启 ProxySQL 才能生效的,它们是:mysql-threads 和 mysql-stacksize


4. Admin管理接口的相关变量


4.1 admin-admin_credentials

admin-admin_credentials 变量控制的是 admin 管理接口的管理员账户。默认的管理员账户和密码为 admin:admin,但是这个默认的用户只能在本地使用。如果想要远程连接到 ProxySQL,例如用 windows 上的 navicat 连接 Linux 上的 ProxySQL 管理接口,必须自定义一个管理员账户

添加管理员用户

//在另一台主机远程登录发现不能使用管理员账号登录
[root@node3 ~]# mysql -uadmin -padmin -h127.0.0.1 -P6032
ERROR 2003 (HY000): C
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值