proxy)及双主结构完整构建过程(2)

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)

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/c3940f6a886eea0c9211e2a7ec45b983.html