基于docker实现mysql的主从复制 详细步骤 (5.7和8.0版本)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
日志服务 SLS,月写入数据量 50GB 1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: 这篇来用docker实现mysql的主从复制

docker安装mysql的详细教程已经放在上篇博文:点这里


这篇来用docker实现mysql的主从复制


首先创建主节点容器

同样使用本机3306端口(上篇博文创建的那个容器已经删掉了,所以没有占用宿主机的3306端口),挂载数据、日志和配置文件三个目录,并设置root用户密码为123456


版本可以是5.7或者8.0


mysql8需要修改一下默认密码校验方式,执行下面命令


ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

挂载的配置文件目录下创建配置文件my.cnf并写入配置如下,注释也写得很清楚

[mysqld]
# 主服务器唯一Id[必填],同一局域网内需要唯一
server-id=1
# 启用二进制日志[必填]
log-bin=mall-mysql-bin
# 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M
# 设置使用的二进制日志格式
binlog_format=mixed
# 二进制日志过期清理时间,默认值为0(不自动清理)
expire_logs_days=7
# 主机,读写都可以
read-only=0
# 设置不要复制的数据库[可选]
binlog-ignore-db=mysql
# 设置需要复制的数据库[可选](输数据库名字) 
#binlog-do-db=test
# 跳过主从复制过程中遇到的所有错误 或 指定类型错误,避免从端复制中断 比如1062是主键重复错误
slave_skip_errors=1062


然后docker restart mysql 重启主节点容器使配置生效


主节点创建用户,授予主从复制权限

进入容器


docker exec -it mysql /bin/bash

使用root用户连接mysql ,并输入密码


mysql -u root -p

创建一个用户slave 密码为123456    5.7版本


CREATE USER 'slave'@'%' IDENTIFIED BY '123456';

创建一个用户slave 密码为123456   8.0版本


CREATE USER 'slave'@'%';

ALTER USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

授予权限


GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

刷新权限


FLUSH PRIVILEGES;

创建从节点容器

命令跟创建主节点差不多,就改了容器名称,映射的本地端口号和数据卷的挂载目录


版本可以是5.7或者8.0,需要跟前面主节点容器版本相同


docker run -d -p 3307:3306 --privileged=true -v /usr/local/mysql/slave/log:/var/log/mysql -v /usr/local/mysql/slave/data:/var/lib/mysql -v /usr/local/mysql/slave/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 --name mysql-slave mysql:5.7

mysql8需要修改一下默认密码校验方式,执行下面命令


ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

在挂载的配置文件目录创建配置文件并写入配置如下


[mysqld]
# 主服务器唯一Id[必填],同一局域网内需要唯一
server-id=2
# 启用二进制日志[必填]
log-bin=mall-mysql-bin
# 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M
# 设置使用的二进制日志格式
binlog_format=mixed
# 二进制日志过期清理时间,默认值为0(不自动清理)
expire_logs_days=7
# 主机,读写都可以
read-only=0
# 设置不要复制的数据库[可选]
binlog-ignore-db=mysql
# 设置需要复制的数据库[可选](输数据库名字) 
#binlog-do-db=test
# 跳过主从复制过程中遇到的所有错误 或 指定类型错误,避免从端复制中断 比如1062是主键重复错误
slave_skip_errors=1062
# 配置中继日志
relay_log=mall-mysql-relay-bin
# slave将复制事件写入自己的二进制日志
log_slave_updates=1
# 设置只读
read_only=1


写完之后docker restart mysql-slave 重启从容器


查看主容器中主从同步的状态

show master status;

可以看到日志文件以及忽略同步的库等信息



在从数据库中配置主从复制

命令说明:


master_host: 主数据库的IP地址


master_port: 主数据库的运行端口


master_user: 主数据库中创建的用于同步数据的用户名称


master_password: 主数据库中创建的用于同步数据的用户密码


master_log_file: 指定从数据库要复制数据的日志文件(通过查看主数据库状态,获取file参数,也就是上一步的查看状态里面的File)


master_log_pos: 指定从数据库从哪个位置开始复制数据(通过查看主数据库状态,获取position参数,也就是上一步的查看状态里面的Position)


master_connect_retry: 连接失败重试的时间间隔,单位为秒


下面命令把参数修改为实际值再执行


change master to master_host='111.111.111.111', master_user='slave', master_password='123456', master_port=3306, master_log_file='mall-mysql-bin.000001', master_log_pos=617, master_connect_retry=30;


查看从数据库中同步状态

show slave status \G;

后面加个\G表示以键值对方式显示,不然数据太多,表格显示在命令行里面看非常乱


可以看到现在还是一个未开始的状态



在从数据库中开启主从复制

start slave;


此时再次查看主从复制状态,可以看到现在已经是yes了



主从复制测试

在主数据库创建库创建表



从数据库查看库表和数据,同样存在




说明主从同步已成功  

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
2月前
|
应用服务中间件 Linux nginx
在虚拟机Docker环境下部署Nginx的步骤。
以上就是在Docker环境下部署Nginx的步骤。需要注意,Docker和Nginix都有很多高级用法和细节需要掌握,以上只是一个基础入门级别的教程。如果你想要更深入地学习和使用它们,请参考官方文档或者其他专业书籍。
122 5
|
5月前
|
Ubuntu 安全 Docker
Ubuntu Server上安装配置Docker的详细步骤
如果一切设置正确,这将下载一个测试镜像,并在容器中运行它,打印一条问候消息。
597 76
|
6月前
|
Ubuntu 安全 数据安全/隐私保护
在Docker容器中部署GitLab服务器的步骤(面向Ubuntu 16.04)
现在,你已经成功地在Docker上部署了GitLab。这就是我们在星际中的壮举,轻松如同土豆一样简单!星际旅行结束,靠岸,打开舱门,迎接全新的代码时代。Prepare to code, astronaut!
463 12
|
7月前
|
算法 Shell 定位技术
在Docker环境下搭建openvslam/orb_slam3的步骤和问题总结
总的来说,搭建openvslam或orb_slam3的过程需要一些耐心和技术知识,但只要你遵循上述步骤,并且在遇到问题时进行适当的调试,你应该能够成功搭建并运行openvslam或orb_slam3。
282 11
|
9月前
|
监控 关系型数据库 MySQL
zabbix7.0.9安装-以宝塔安装形式-非docker容器安装方法-系统采用AlmaLinux9系统-最佳匹配操作系统提供稳定运行环境-安装教程完整版本-优雅草卓伊凡
zabbix7.0.9安装-以宝塔安装形式-非docker容器安装方法-系统采用AlmaLinux9系统-最佳匹配操作系统提供稳定运行环境-安装教程完整版本-优雅草卓伊凡
601 30
|
9月前
|
Ubuntu 关系型数据库 MySQL
容器技术实践:在Ubuntu上使用Docker安装MySQL的步骤。
通过以上的操作,你已经步入了Docker和MySQL的世界,享受了容器技术给你带来的便利。这个旅程中你可能会遇到各种挑战,但是只要你沿着我们划定的路线行进,你就一定可以达到目的地。这就是Ubuntu、Docker和MySQL的灵魂所在,它们为你开辟了一条通往新探索的道路,带你亲身感受到了技术的力量。欢迎在Ubuntu的广阔大海中探索,用Docker技术引领你的航行,随时准备感受新技术带来的震撼和乐趣。
367 16
|
10月前
|
SQL 网络协议 关系型数据库
MySQL 主从复制
主从复制是 MySQL 实现数据冗余和高可用性的关键技术。主库通过 binlog 记录操作,从库异步获取并回放这些日志,确保数据一致性。搭建主从复制需满足:多个数据库实例、主库开启 binlog、不同 server_id、创建复制用户、从库恢复主库数据、配置复制信息并开启复制线程。通过 `change master to` 和 `start slave` 命令启动复制,使用 `show slave status` 检查同步状态。常见问题包括 IO 和 SQL 线程故障,可通过重置和重新配置解决。延时原因涉及主库写入延迟、DUMP 线程性能及从库 SQL 线程串行执行等,需优化配置或启用并行处理
248 40
|
10月前
|
关系型数据库 MySQL 数据库
RDS用多了,你还知道MySQL主从复制底层原理和实现方案吗?
随着数据量增长和业务扩展,单个数据库难以满足需求,需调整为集群模式以实现负载均衡和读写分离。MySQL主从复制是常见的高可用架构,通过binlog日志同步数据,确保主从数据一致性。本文详细介绍MySQL主从复制原理及配置步骤,包括一主二从集群的搭建过程,帮助读者实现稳定可靠的数据库高可用架构。
545 9
RDS用多了,你还知道MySQL主从复制底层原理和实现方案吗?
|
8月前
|
前端开发 Linux Docker
docker的安装使用0废话版本自学软硬件工程师778天
win11怎么安装docker的必要设置自学软硬件工程师778天
|
10月前
|
SQL 存储 关系型数据库
MySQL主从复制 —— 作用、原理、数据一致性,异步复制、半同步复制、组复制
MySQL主从复制 作用、原理—主库线程、I/O线程、SQL线程;主从同步要求,主从延迟原因及解决方案;数据一致性,异步复制、半同步复制、组复制
1000 11