30-mysql-proxy完成负载均衡与读写分离

MySQL Proxy就是这么一个中间层代理,简单的说,MySQL Proxy就是一个连接池,负责将前台应用的连接请求转发给后台的数据库,并且通过使用lua脚本,可以实现复杂的连接控制和过滤,从而实现读写分离和负载平衡


下载安装mysql_proxy:
http://mysql.cdpa.nsysu.edu.tw/Downloads/MySQL-Proxy/mysql-proxy-0.8.3-linux-glibc2.3-x86-64bit.tar.gz

PS:解压后该目录包含已经编译好的二进制文件


1.利用mysql_proxy实现负载均衡

cd /usr/local/mysql-proxy

设置主主负载均衡:

./bin/mysql-proxy -P 192.168.61.159:4040 --proxy-backend-addresses=192.168.61.158:3306 --proxy-backend-addresses=192.168.61.159:3306


设置主从负载均衡:

./bin/mysql-proxy  \
--proxy-backend-addresses=192.168.1.199:3306 \
--proxy-read-only-backend-addresses=192.168.1.200:3306 \
--proxy-lua-script=/usr/local/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua

//最后一行是指定lua来指定读写分离



2.连接mysql_proxy,用mysql客户就可以,因为proxy是mysql的前端代理
注意proxy的端口是4040


在连接上之后,做sql查询,却总是往某1台mysql server来发送------负载均衡没体现出来?
答: 不是没体现出来.
均衡不是体现在sql语句,一会请求mysqlA服,一会请求mysqlB服.一会update一会delete,这样很容易会导致数据不一致
均衡是体现”连接”的均衡上.,



mysql_proxy会把连接mysql服务器的tcp/IP连接缓存进连接池,以提高性能.
在缓存池里, 缓存的连接大致是平均分配在每台mysql服务器上.
但具体的每一个连接,始终连某台服务器.


测试主主负载均衡方法:

1.两台mysql服务器都设置各自的id自增长的不同的每步增长

2.在客户端建立多个mysql-proxy的连接,然后在多个客户端执行insert语句,最后查看两个主主服务器的自增长的id标识


在进行读写分离测试前,必须修改其lua文件的参数:

编辑/usr/local/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua文件,lua代码如下:

-- connection pool
if not proxy.global.config.rwsplit then
        proxy.global.config.rwsplit = {
                min_idle_connections = 4,
                max_idle_connections = 8,


                is_debug = false
        }
end

 min_idle_connections修改为1,max_idle_connections修改为2


测试主从负载均衡方法:

1.两台mysql服务器都设置各自的id自增长的不同的每步增长

检验读分离:

在从服务器上insert一条独立于主服务器的记录,然后在多个客户端进行查询操作,如果能读到新增的记录,那么说明读已经分离成功

检验写分离:

在客户端进行insert操作,然后看服务器上的记录的自增id是主服务器的id标识还是从服务器的标识


补充:

加上参数--daemon可以让mysql-proxy在后台运行

你可能感兴趣的:(30-mysql-proxy完成负载均衡与读写分离)