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的监听端口。