mysql主从配置代理_MySQL-Proxy主从搭建读写分离全过程

MySQL-proxy是什么,大家都知道,不知道的就别往下看了...

下载mysql-proxy最新版,本文撰写时最新版本为

安装mysql-proxy步骤如下:

tar zxvf mysql-proxy-0.8.1-linux-glibc2.3-x86-32bit.gz

cp mysql-proxy-0.8.1-linux-glibc2.3-x86-32bit /usr/loc/proxy-mysql

新建或编辑/etc/mysql-proxy.cnf文件,添加以下内容(具体参数根据实际情况修改):

vi /etc/mysql-proxy.cnf

[mysql-proxy]

admin-username = zhangdongyu

admin-password = 123123

daemon = true

keepalive = true

proxy-backend-addresses = 192.168.0.88:3306

proxy-read-only-backend-addresses = 192.168.0.88:3307

proxy-lua-script = /usr/local/proxy-mysql/share/doc/mysql-proxy/rw-splitting.lua

admin-lua-script = /usr/local/proxy-mysql/share/doc/mysql-proxy/admin-sql.lua

log-file = /usr/local/proxy-mysql/cn.log

log-level = debug

主要参数注解:

proxy-backend-addressesmysql主库(写)地址

proxy-read-only-backend-addressesmysql从库(读)地址

proxy-lua-script读写分离脚本

admin-lua-scriptadmin脚本

admin-username数据库用户名(主从上都需建立相同用户)

admin-password数据库密码

daemondaemon进程运行

keepalive保持连接(启动进程会有2个,一号进程用来监视二号进行,如果二号进程死掉自动重建,此参数在旧版本中无法使用)

编辑profile/.bash_profile脚本

vi /etc/profile(或者.bash_profile)

LUA_PATH="/usr/local/proxy-mysql/share/doc/mysql-proxy/?.lua"

export LUA_PATH

export PATH=$PATH:/usr/local/proxy-mysql/bin

:wq

source /etc/profile

为方便建立建立mysql-proxy.sh脚本

#!/bin/bash

mode=$1

if [ -z "$mode" ] ; then

mode="start"

fi

case $mode in

start)

mysql-proxy --defaults-file=/etc/mysql-proxy.cnf>/usr/local/proxy-mysql/cn.log &

;;

stop)

killall -9 mysql-proxy

;;

restart)

if $0 stop ; then

$0 start

else

echo"Restart failed!"

exit 1

fi

;;

esac

exit 0

启动mysql-proxy

sh脚本

启动:./mysql-proxy.sh或./mysql-proxy.sh start

启动日志

ac21daf6bd75987a6f6a1cd629ca7008.gif

重启:./mysql-proxy.sh restart

停止:./mysql-proxy.sh stop

测试:

为达到测试效果,修改admin-sql.lua脚本以下两行

vi /usr/local/proxy-mysql/share/doc/mysql-proxy/rw-splitting.lua

if not proxy.global.config.rwsplit then

proxy.global.config.rwsplit = {

min_idle_connections = 1,#修改最小连接为1

max_idle_connections = 2,#修改最大连接为2

is_debug = true#debug为true

}

end

重启mysql-proxy代理

开启两个终端分别连接代理:

ONE:./mysql -h192.168.0.88 -uzhangdongyu -p123123 -P4040

TWO:./mysql -h192.168.0.88 -uzhangdongyu -p123123 -P4040

可看到连接成功信息:

ff13c64225fb6a0cea3075890116a620.gif

操作ONE客户端:

执行select语句观察数据库log文件

select * from z_member_info;

观察主从库日志文件,发现查询发生在主库?

主库:192.168.0.88:3306日志文件:tail -f /usr/local/mysql/localstate/mysqlexecute.log

10bae2b0cc115f553416db5283aeb0f1.gif

这是因为mysql-proxy代理会检测客户端连接,当连接没有超过min_idle_connections预设值时,不会进行读写分离,即查询操作会发生到主库上。

操作TWO客户端:

执行select语句观察数据库log文件

select * from z_member_info;

观察主从库日志文件,发现主库没有任何记录,查询日志记录在从库。

从库:192.168.0.88:3306日志文件:tail -f /usr/local/mysql3307/localstate/mysqlexecute.log

33954528bad4573ee5fb5f0270417b4a.gif

操作两个终端进行insert操作,会发现写操作始终被主库(3306)日志文件记录。

92beca0ada1cf989305b53d4e69479e0.gif

至此mysql-proxy安装测试完成。

注:生产环境一定要根据实际情况配置相关文件,至于lua文件强烈推荐读者自行,目前正在研究lua文件的优化与定制,不久会发上来。0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值