文章目录
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