阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

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

425次阅读
没有评论

共计 3397 个字符,预计需要花费 9 分钟才能阅读完成。

1. 安装和配置 Docker

服务器版本
阿里云 CentOS7.4

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

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

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;

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

修改从库配置文件

#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,表示启动同步成功

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

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

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

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

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

 

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

 

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 表

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

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

主库:MySQL 主从复制 mysql-proxy 实现读写分离

从库:MySQL 主从复制 mysql-proxy 实现读写分离

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

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

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

主库:MySQL 主从复制 mysql-proxy 实现读写分离

从库:MySQL 主从复制 mysql-proxy 实现读写分离

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

Ubuntu 16.04 下实现 MySQL 主从复制  https://www.linuxidc.com/Linux/2017-08/146624.htm
MySQL 5.6.26 主从复制报错 1050  https://www.linuxidc.com/Linux/2017-08/146203.htm
MySQL 主从复制详解 https://www.linuxidc.com/Linux/2017-10/147550.htm
MySQL 基于 GTID 主从复制之半同步复制 https://www.linuxidc.com/Linux/2018-05/152175tm
MySQL 主从复制——主库已有数据的解决方案  https://www.linuxidc.com/Linux/2018-07/153283.htm
基于 Docker 的 MySQL 主从复制搭建 https://www.linuxidc.com/Linux/2018-07/153268.htm
MySQL 主从复制读写分离与高可用配置 https://www.linuxidc.com/Linux/2018-04/151893.htm
mysql-proxy 代理加 MySQL 主从实现读写分离 https://www.linuxidc.com/Linux/2017-05/143453.htm
CentOS 7.4 下 MySQL+Amoeba 实现主从同步读写分离  https://www.linuxidc.com/Linux/2018-03/151648.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计3397字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7805482
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换...
星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的NAS中!

星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的NAS中!

星哥带你玩飞牛 NAS-10:备份微信聊天记录、数据到你的 NAS 中! 大家对「数据安全感」的需求越来越高 ...
自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个 AI 智能体 — 跟创业大佬对话 前言 智能体(Agent)已经成为创业者和技术人绕...
2025年11月28日-Cloudflare史诗级事故:一次配置失误,引爆全球宕机

2025年11月28日-Cloudflare史诗级事故:一次配置失误,引爆全球宕机

2025 年 11 月 28 日 -Cloudflare 史诗级事故: 一次配置失误,引爆全球宕机 前言 继今...
免费领取huggingface的2核16G云服务器,超简单教程

免费领取huggingface的2核16G云服务器,超简单教程

免费领取 huggingface 的 2 核 16G 云服务器,超简单教程 前言 HuggingFace.co...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
开源MoneyPrinterTurbo 利用AI大模型,一键生成高清短视频!

开源MoneyPrinterTurbo 利用AI大模型,一键生成高清短视频!

  开源 MoneyPrinterTurbo 利用 AI 大模型,一键生成高清短视频! 在短视频内容...
星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

  星哥带你玩飞牛 NAS-16:不再错过公众号更新,飞牛 NAS 搭建 RSS 对于经常关注多个微...
告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

  告别 Notion 焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁” 引言 在数字笔记工...
星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛 NAS 硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话? 前言 在选择 NAS 用预...
多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞...