读写分离的利器——MySQL Proxy

0 引言

MySQL Proxy是一个位于客户端和MySQL服务器端之间的程序,通过它可以实现监听和管理客户端与MySQL服务器端之间的通信,最大的作用是实现数据库的读写分离,从而达到负载均衡的目的。

MySQL Proxy的常用用途包括负载平衡、故障分析、查询分析、查询过滤和修改等。作为一个中间层代理,通俗地说,它就是一个连接池,负责将前台应用的连接请求转发给后台的数据库,并且通过使用lua脚本,可以实现复杂的连接控制和过滤,从而实现读写分离和负载平衡。对于应用程序来说,MySQL Proxy是完全透明的,应用程序只需要连接到MySQL Proxy的监听端口即可。MySQL Proxy最强大的功能是实现"读写分离",基本原理是让主数据库处理事务性查询,让从数据库处理SELECT查询,最后通过数据库的复制功能把事务性查询导致的数据变更同步到集群中的从数据库中。

如果此时只有一个MySQL Proxy机器,可能会出现单点失效的问题,解决办法是使用多个proxy机器作为冗余,在应用服务器的连接池配置中配置多个proxy的连接参数即可。

MySQL Proxy通过mysql-proxy来指定配置的参数。下面了解一下该命令常用参数的含义:

● --proxy-backend-addresses:该参数用来指定MySQL服务器的IP地址和端口号,如果代理多个服务器,可以用逗号分隔。

● --proxy-read-only-backend-addresses:该参数用来指定只读服务器的IP地址和端口号,如果代理多个服务器,可以用逗号分隔。

● --proxy-skip-profiling:该参数用来设置是否禁用查询性能分析。

● --proxy-lua-script:该参数用来指定lua脚本文件。

● --daemon:采用daemon方式启动。

● --admin-address:指定MySQL Proxy的管理端口。

● --proxy-address=:指定mMySQL Proxy的监听端口。

相关推荐
雪度娃娃12 分钟前
存储器层次结构——磁盘硬盘存储
服务器·网络·数据库·计算机组成原理
暴力求解30 分钟前
Mysql数据库基础
数据库·mysql·操作系统
意倾城1 小时前
MySQL最左前缀匹配原则
数据库·mysql
暴躁小师兄数据学院1 小时前
【AI大数据工程师特训笔记】第13讲:数据库性能手术刀
大数据·数据库·数据仓库·sql·postgresql
步十人2 小时前
【Redis】持久化机制
数据库·redis·缓存
Quincy_Freak2 小时前
银河麒麟aarch64如何高效做数据分析?分享一款内网离线数据分析利器
大数据·数据库·数据挖掘·数据分析·aarch64
香气袭人知骤暖2 小时前
PG数据库 Docker 容器自动备份方案
数据库·docker·容器
me8323 小时前
【Linux】Linux 目录命名规范溯源(Linux各个目录究竟是干嘛的)
linux·运维·数据库
土狗TuGou3 小时前
SQL内功笔记 · 第2篇:列的约束
数据库·笔记·sql
java_cj3 小时前
MySQL 执行原理深度剖析:查询成本计算与优化器内幕
数据库·后端·mysql