mysql proxy 读写分离_MySQL主从复制 mysql-proxy实现读写分离

1.安装和配置Docker

服务器版本

阿里云CentOS7.4

docker版本

18.06.0-ce

docker安装步骤

https://docs.docker.com/install/linux/docker-ce/centos/#install-docker-ce-1

# docker pull mysql:5.7

启动两个mysql镜像,分别映射3306和3316端口

主库:3306端口

备库:3316端口

# docker run -p 3306:3306 --name mysql3306 -v /opt/mysql/data/data3306:/var/lib/mysql  -v /opt/mysql/logs/logs3306:/logs -e MYSQL_ROOT_PASSWORD=xxxxxxxxxxxx -d mysql:5.7

# docker run -p 3316:3306 --name mysql3316 -v /opt/mysql/data/data3316:/var/lib/mysql  -v /opt/mysql/logs/logs3316:/logs -e MYSQL_ROOT_PASSWORD=xxxxxxxxxxxx -d mysql:5.7

4bbdf8ab584fd69a18595bfcfd4ee118.png

2.配置主从复制

从主库的docker容器中把默认的配置文件拷贝出来

# docker cp 37735c072370:/etc/mysql/mysql.conf.d/mysqld.cnf /opt/mysql/conf/conf3306

修改配置文件增加两行

#vim mysqld.cnf

[mysqld]

log-bin=mysql-bin #开启二进制日志

server-id=1 #设置server-id

将修改后的配置文件拷回容器里,并重启容器

# docker cp /opt/mysql/conf/conf3306/mysqld.cnf 37735c072370:/etc/mysql/mysql.conf.d/

# docker restart 37735c072370

创建主从复制需要的mysql账户,并分配权限

mysql>CREATE USER 'repl'@'xxx.xxx.xxx.xxx' IDENTIFIED BY 'repl123';

mysql>GRANT REPLICATION SLAVE ON *.* TO 'repl'@'xxx.xxx.xxx.xxx'

查看主库状态,记录下File和Position

mysql>SHOW MASTER STATUS;

beff1c6ccef58d9eca14bf3b39903d1f.png

修改从库配置文件

#vim mysqld.cnf

[mysqld]

server-id=2 #设置server-id

同样拷进从库镜像,并重启容器

mysql中执行配置主库的语句

mysql>change master to master_host='xxx.xxx.xxx.xxx', #Master 服务器Ip

master_port=3306,

master_user='repl',

master_password='repl123',

master_log_file='master-bin.000001',#Master服务器产生的日志

master_log_pos=2986;

mysql>start slave;

mysql>show slave status\G

如果slave_io_running和slave_sql_running都为yes,表示启动同步成功

ad165fa8fc00a9d2c71e11c08d2eef77.png

建立两个客户端连接并创建测试库

d0d008d30012c54f84e873e648bf1a7b.png

主库建立student表并插入一条记录,可以看到,从库自动同步了数据,配置成功

2a99b6cb26e4fff2091e26f7a6716735.png     

84e97b252967e3cac09081eb487ceb06.png

9e00b6a30eb8bb4201cc59eddf2dd5ae.png   

0195c144b7d130866bd65a2bae2b1340.png

3.用mysql-proxy实现读写分离

下载mysql-proxy

https://downloads.mysql.com/archives/proxy/

解压并配置mysql-proxy

# tar zxvf mysql-proxy-0.8.5-linux-el6-x86-64bit.tar.gz

# cd mysql-proxy-0.8.5-linux-el6-x86-64bit

# vim /etc/mysql-proxy.cnf

[mysql-proxy]

user=root #运行mysql-proxy用户

admin-username=proxy #主从mysql共有的用户

admin-password=proxy123 #共有用户密码

proxy-read-only-backend-addresses=xxx.xxx.xxx.xxx:3316 #备库地址

proxy-backend-addresses=xxx.xxx.xxx.xxx:3306 #主库地址

proxy-lua-script=/usr/local/mysql-proxy/mysql-proxy-0.8.5-linux-el6-x86-64bit/share/doc/mysql-proxy/rw-splitting.lua #指定读写分离配置文件位置

admin-lua-script=/usr/local/mysql-proxy/mysql-proxy-0.8.5-linux-el6-x86-64bit/share/doc/mysql-proxy/admin-sql.lua #指定管理脚本

daemon=true #以守护进程方式运行

keepalive=true #mysql-proxy崩溃时,尝试重启

修改读写分离配置文件

# vim /usr/local/mysql-proxy/mysql-proxy-0.8.5-linux-el6-x86-64bit/share/doc/mysql-proxy/rw-splitting.lua

min_idle_connections = 1, #默认超过4个连接数时才开始读写分离,改为1

max_idle_connections = 1,

mysql-proxy的bin目录下启动mysql-proxy

# ./mysql-proxy --defaults-file=/etc/mysql-proxy.cnf

主库和从库分别创建用户

mysql>GRANT ALL ON *.* TO 'proxy'@'xxx.xxx.xxx' identified by 'proxy123';

创建mysql-proxy的数据里连接(默认端口4040),可以看到之前验证主从复制时简历的test库和student表

ef3d36b5a650b9c69b29081f7084e20f.png

只修改从库的数据,然后通过mysql-proxy查询,可以看到读取的数据是从库修改过的数据,读分离验证成功。

主库:

163d343e0c40658a18e1c71628924088.png

从库:

05289c5500b7b03d0421b531970840e9.png

mysql-proxy:

03fb16fee76f4207468272a1bdcf416d.png

停止从库的docker容器,通过mysql-proxy插入一条数据,主库中刷新也有新增的数据,写分离验证成功。

mysql-proxy:

05910ffa275d409de3f9f71b3a54086a.png

主库:

52e7820562ba24c590c91a83b77a7c39.png

从库:

2534a9d00ab649fe11df7d95027a5eca.png

至此,mysql的主从复制已经通过mysql-proxy实现读写分离已实现。

0b1331709591d260c1c78e86d0c51c18.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值