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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 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了



主从复制测试

在主数据库创建库创建表



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




说明主从同步已成功  

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
20天前
|
机器人 网络安全 数据安全/隐私保护
autMan奥特曼机器人-对接Docker版本NTQQ详细教程
本文介绍了如何在服务器上搭建NTQQ机器人,通过官方NTQQ对接各框架,实现QQ登录的稳定运行。文章提到了需要准备一台服务器和相应的软件,并详细描述了通过SSH链接服务器、创建文件夹和配置文件、编辑配置文件地址端口、运行容器等步骤。同时,文章还介绍了VNC连接的使用和配置,以及使用watchtower进行NTQQ的更新。文章总结起来就是在服务器上搭建NTQQ机器人,实现QQ登录的稳定性和自动登录功能,同时提供了更新和维护的方法。
53 3
autMan奥特曼机器人-对接Docker版本NTQQ详细教程
|
13天前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
26天前
|
关系型数据库 MySQL Linux
Docker安装Mysql5.7,解决无法访问DockerHub问题
当 Docker Hub 无法访问时,可以通过配置国内镜像加速来解决应用安装失败和镜像拉取超时的问题。本文介绍了如何在 CentOS 上一键配置国内镜像加速,并成功拉取 MySQL 5.7 镜像。
223 2
Docker安装Mysql5.7,解决无法访问DockerHub问题
|
13天前
|
NoSQL 安全 关系型数据库
2024Mysql And Redis基础与进阶操作系列(6)作者——LJS[含MySQL 多表之一对一/多;多对多;多表联合查询等详解步骤及常见报错问题所对应的解决方法]
MySQL 多表之一对一/多;多对多;多表联合之交叉连接;内连接;左、右、外、满、连接;子查询及关键字;自连接查询等详解步骤及常见报错问题所对应的解决方法
|
10天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
35 3
|
13天前
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法
|
10天前
|
关系型数据库 MySQL Docker
docker环境下mysql镜像启动后权限更改问题的解决
在Docker环境下运行MySQL容器时,权限问题是一个常见的困扰。通过正确设置目录和文件的权限,可以确保MySQL容器顺利启动并正常运行。本文提供了多种解决方案,包括在主机上设置正确的权限、使用Dockerfile和Docker Compose进行配置、在容器启动后手动更改权限以及使用 `init`脚本自动更改权限。根据实际情况选择合适的方法,可以有效解决MySQL容器启动后的权限问题。希望本文对您在Docker环境下运行MySQL容器有所帮助。
19 1
|
11天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
22 2
|
13天前
|
SQL NoSQL 关系型数据库
|
13天前
|
存储 SQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Mysql And Redis基础与进阶操作系列(1)之[MySQL的下载、安装、配置详解步骤及报错对应解决方法]