读写分离的利器——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的监听端口。

相关推荐
白如意i19 分钟前
在Ubuntu 16.04上安装最新版本的MySQL的方法
linux·mysql·ubuntu
百成Java1 小时前
基于Spring Boot的旅游网站
java·开发语言·spring boot·后端·mysql
小城里的梦想1 小时前
redis和mysql端口修改
数据库·redis·mysql
光锥智能1 小时前
OceanBase云数据库战略实施两年,受零售、支付、制造行业青睐
数据库·oceanbase·零售
赤鸢QAQ1 小时前
pyqt瀑布流布局
数据库·pyqt
极客先躯2 小时前
高级java每日一道面试题-2024年9月29日-数据库篇-索引怎么定义,分哪几种?
java·数据结构·数据库·分类·索引·全文索引·聚集索引
F_D_Z2 小时前
【SQL】重复的邮箱信息
数据库·sql
Jasonakeke2 小时前
【重学 MySQL】四十、SQL 语句执行过程
数据库·sql·mysql
尘浮生3 小时前
Java项目实战II基于Java+Spring Boot+MySQL的新闻稿件管理系统(源码+数据库+文档)
java·开发语言·数据库·spring boot·mysql·maven·intellij-idea
程序那点事儿3 小时前
MongoDB 工具包安装(mongodb-database-tools)
数据库·mongodb