Docker-Mysql-proxy Mysql实现读写分离与负载
原理
MySQL Proxy处于客户端应用程序和MySQL服务器之间,通过截断、改变并转发客户端和后端数据库之间的通信来实现其功能。
MySQL Proxy就是这么一个中间层代理,简单的说,MySQL Proxy就是一个连接池,负责将前台应用的连接请求转发给后台的数据库,并且通过使用lua脚本,可以实现复杂的连接控制和过滤,从而实现读写分离和负载平衡。对于应用来说,MySQL Proxy是完全透明的,应用则只需要连接到MySQL Proxy的监听端口即可。当然,这样proxy机器可能成为单点失效,但完全可以使用多个proxy机器做为冗余,在应用服务器的连接池配置中配置到多个proxy的连接参数即可。
负载解析
mysql-proxy负载均衡是体现在“连接”的均衡上。mysql_proxy会把连接mysql服务器的TCP/IP连接缓存进连接池以提高性能在缓存池里,缓存的连接大致是平均分配在每台mysql服务器上,但具体的每一个连接,始终连接某台服务器。所以在出现了mysql的sql查询时,却总往某一台mysql server来发送是这么回事的。
资源
准备
2个正在运行的mysql。
一个centos,部署mysql-proxy。
ngvicat,用于测试。
配置
通过docker启动2个运行的mysql环境
docker run -tid -p 3307:3306 --name mysql_master -e MYSQL_ROOT_PASSWORD=123456 mysql:5.6docker run -tid -p 3308:3306 --na