2,实现读写分离是有lua脚本实现的,现在mysql-proxy里面已经集成,无需再安装。
3,配置连接数达到多少才读写分离,此处改为1,1个连接就开始读写分离
vim /usr/share/mysql-proxy/rw-splitting.lua
4,启动mysql-proxy,主库用于写172.16.34.212,从库用于读172.16.34.156
sudo mysql-proxy –proxy-read-only-backend-addresses=172.16.34.156:3306 –proxy-backend-addresses=172.16.34.212:3306 –proxy-lua-script=/usr/share/mysql-proxy/rw-splitting.lua –admin-username=euht
–admin-password=123456
–admin-lua-script=/usr/share/mysql-proxy/admin.lua
5,启动后默认占用端口4040和4041。4040用于SQL转发,4041用于管理mysql-proxy。(netstat -tupln|grep mysql-proxy)
6,测试读写分离
用主库172.16.34.212的用户euht在这台mysql-proxy服务器登录进去(也可以单独为这个代理创建一个用户)
现在从这台代理登录进主mysql服务器插入一条数据到testtb,结果为主从两台服务器都有数据了。
为了测试读写是否真的分离了,我们把这两台服服务器的数据差异化
先登录mysql-proxy代理(-P指定端口号,必须指定否则登录进去的将是本地3306端口的那个,当然由于这台219服务器我没配置让外部机子可以访问,所以执行下面的语句缺少端口号直接报错。)
mysql -ueuht -p -h172.16.34.219 -P4040
登录进去我们为了看到读写分离是否生效,先到从服务器156把slave给停掉。(stop slave;)然后在代理服务器219的mysql-proxy执行插入数据。先看原本的数据情况
插入数据和查看数据
发现插入数据成功,再select出来居然没有刚才插入的数据。这时我们分别到两台服务器去查看数据。
172.16.156从服务器的数据还是原来的
再看212的数据
看到这里就看到效果了。主服务器已经有了刚才插入的数据,从服务器没有。这是因为从服务器的主从复制已经关闭,所以从mysql-proxy代理端插入数据(实际上是用了主服务器212去插入)没有复制到从服务器。从mysql-proxy读取没看到新插入的数据是因为代理端是去从服务器156读取数据的。
至此,mysql的主从复制和读写分离就结束了。下面简单说一下双主结构。
Mysql双主结构
通过上面的介绍很容易看出,双主结构其实就是两台服务器相互数据复制。那么做到双主结构只需要把212主服务器变成156的从服务器即可。
在212服务器上执行(先到156查看日志位置,改对相应的东西即可show master status;)
change master to
master_host=’172.16.34.212’,
master_user=’euht’,
master_password=’123456’,
master_log_file=’master-bin.000001’,
master_log_pos=294;
开启主从
mysql> start slave;
156,212都start slave,而且配置互为slave,这就是双主结构。
测试,212插入数据156会同步,156插入数据212会同步。经测试全部通过。(记得查看运行状态,Slave_IO_Running 与 Slave_SQL_Running 的值都必须为YES,才表明状态正常。Show slave status\G)