设为首页 加入收藏

TOP

MySQL主从复制 mysql-proxy实现读写分离
2018-08-16 09:31:29 】 浏览:113
Tags:MySQL 主从 复制 mysql-proxy 实现 读写 分离

1.安装和配置Docker


docker版本
18.06.0-ce


docker安装步骤
https://docs.docker.com/install/linux/docker-ce/centos/#install-docker-ce-1


下载mysql镜像


# 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


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;



修改从库配置文件


#vim mysqld.cnf
[mysqld]
server-id=2 #设置server-id


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


mysql中执行配置主库的语句


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



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



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


     


 


    


 


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


下载mysql-proxy
https://downloads.mysql.com/archives/proxy/


解压并配置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表



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


主库:


从库:


mysql-proxy:


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


mysql-proxy:


主库:


从库:


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


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇CentOS 7.5下安装单实例MySQL 5.7 下一篇Oracle 118C 版本发布策略的变更

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目