Docker-Mysql-proxy Mysql Proxy实现读写分离

 

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来发送是这么回事的。

资源

准备

  1. 2个正在运行的mysql。
  2. 一个centos,部署mysql-proxy。
  3. ngvicat,用于测试。

配置

  1. 经过docker启动2个运行的mysql环境
docker run -tid -p 3307:3306 --name mysql_master -e MYSQL_ROOT_PASSWORD=123456 mysql:5.6
docker run -tid -p 3308:3306 --name mysql_slave -e MYSQL_ROOT_PASSWORD=123456 mysql:5.6

   2. 配置mysql-proxymysql

wget https://downloads.mysql.com/archives/get/file/mysql-proxy-0.8.5-linux-debian6.0-x86-64bit.tar.gz
tar zxvf mysql-proxy-0.8.5-linux-debian6.0-x86-64bit.tar.gz
mv mysql-proxy-0.8.5-linux-debian6.0-x86-64bit mysql-proxy cd /usr/local/mysql-proxy mkdir lua #建立脚本存放目录 mkdir logs #建立日志目录 touch logs/mysql-proxy.log chmod 777 logs/mysql-proxy.log cp share/doc/mysql-proxy/rw-splitting.lua ./lua #复制读写分离配置文件 cp share/doc/mysql-proxy/admin-sql.lua ./lua #复制管理脚本
vi /etc/mysql-proxy.cnf   #建立配置文件

  3. 配置文件linux

[mysql-proxy]
user=root #运行mysql-proxy用户 log-level=info #定义log日志级别,由高到低分别有(error|warning|info|message|debug) log-file=/usr/local/mysql-proxy/logs/mysql-proxy.log #日志位置 proxy-address=172.17.0.5:4040 #mysql-proxy运行ip和端口,不加端口,默认4040 proxy-backend-addresses=172.17.0.2:3306 #指定后端主master写入数据 proxy-read-only-backend-addresses=172.17.0.3:3306 #指定后端从slave读取数据 proxy-lua-script=/usr/local/mysql-proxy/lua/rw-splitting.lua #指定读写分离配置文件位置 admin-lua-script=/usr/local/mysql-proxy/lua/admin-sql.lua #指定管理脚本 daemon=true #以守护进程方式运行 keepalive=true #mysql-proxy崩溃时,尝试重启
   4. 配置完成,保存退出!
chmod 660 /etc/mysql-porxy.cnf
 

修改读写分离配置文件

vi /usr/local/mysql-proxy/lua/rw-splitting.lua
找到下面的代码,覆盖对应部分便可,其他代码均保留不变。


if not proxy.global.config.rwsplit then proxy.global.config.rwsplit = { min_idle_connections = 1, #默认超过4个链接数时,才开始读写分离,改成1 max_idle_connections = 1, #默认8,改成1 is_debug = false } end
 

注意

  • 配置文件中的注视不能保留,不然启动的的时候可能报错。
  • 使用下列第一种启用方式则不须要配置,但一般状况下,咱们则会使用配置文件启动。 

启动方式2种

  1. 经过命令行启动
/usr/local/mysql-proxy/bin/mysql-proxy --proxy-backend-addresses=172.17.0.5:3306 --proxy-backend-addresses=172.17.0.3:3306 --proxy-backend-addresses=172.17.0.2:3306
  1. 经过配置文件启动
/usr/local/mysql-proxy/bin/mysql-proxy --defaults-file=/etc/mysql-proxy.cnf &

加&是置于后台运行。

测试

 
 
 

出现错误分析

  1. mysql-proxy代理的服务器中(逻辑数据库)不能链接到其余两台服务器(物理数据库)。可能缘由:3者未处于同一网桥中。解决方法:要么不创建网络network,要么建立于同一个network中。
 
  1. 经过配置文件启动报以下错误。解决方法:赋予配置文件600权限便可。chmod 600 /etc/mysql-proxy.cnf。 
  1. 服务未正常启动,查看对应的日志文件。可能错误,配置中存在注释,致使出现多个日志文件,存在错误。
 
  1. 检查配置文件中的lua文件是否存在对应的目录中,若是没有则复制进去。
 
相关文章
相关标签/搜索