IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> 一文搞定MySQL主从复制 - Docker版本 -> 正文阅读

[系统运维]一文搞定MySQL主从复制 - Docker版本

一:提前创建好挂载目录

# 主数据库data文件夹
mkdir -p /usr/docker/mysql/master/data/
# 主数据库配置文件夹
mkdir -p /usr/docker/mysql/master/conf.d/

# 从数据库data文件夹
mkdir -p /usr/docker/mysql/slave/data/
# 从数据库配置文件夹
mkdir -p /usr/docker/mysql/slave/conf.d/

在各自的 conf.d 文件夹中创建 my.cnf 配置文件

# 主库
cd /usr/docker/mysql/master/conf.d/
touch my.cnf

# 从库
cd /usr/docker/mysql/slave/conf.d/
touch my.cnf

二:运行MySQL容器 5.7 为例子

主数据库

docker run \
--privileged=true \
-v /usr/docker/mysql/master/conf.d/my.cnf:/etc/my.cnf \
-v /usr/docker/mysql/master/data/:/var/lib/mysql \
-p 3366:3306 \
--name master-mysql1 \
-e MYSQL_ROOT_PASSWORD='root' \
-d mysql:5.7

从数据库

docker run \
--privileged=true \
-v /usr/docker/mysql/slave/conf.d/my.cnf:/etc/my.cnf \
-v /usr/docker/mysql/slave/data/:/var/lib/mysql \
-p 3367:3306 \
--name slave-mysql1 \
-e MYSQL_ROOT_PASSWORD='root' \
-d mysql:5.7

三:修改主从库配置文件

主库

 vim /usr/docker/mysql/master/conf.d/my.cnf

[mysqld]
## 同一局域网内注意要唯一
server-id=100  
## 开启二进制日志功能,可以随便取(关键)
log-bin=mysql-bin

从库

 vim /usr/docker/mysql/slave/conf.d/my.cnf
[mysqld]
## 设置server_id,注意要唯一
server-id=101  
## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
log-bin=mysql-slave-bin   
## relay_log配置中继日志
relay_log=edu-mysql-relay-bin  

四:重启主从库数据库服务

主库

# 进入容器
docker exec -it master-mysql1 /bin/bash

# 重启MySQL服务
service mysql restart

# 退出容器
exit

# 启动容器
docker start master-mysql1

从库

# 进入容器
docker exec -it slave-mysql1 /bin/bash

# 重启MySQL服务
service mysql restart

# 退出容器
exit

# 启动容器
docker start slave-mysql1

五:进入主库容器创建Slave用户

# 进入容器
docker exec -it master-mysql1 /bin/bash

# 进入MySQL
mysql -uroot -proot

# 创建slave用户
CREATE USER 'slave'@'%' IDENTIFIED BY '123456';

# 授予权限
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

六:查看主库的信息

# 查看信息
show master status;

image-20211016204045843

记住File 和 Position 的值

File和Position字段的值后面将会用到,在后面的操作完成之前,需要保证Master库不能做任何操作,否则将会引起状态变化,File和Position字段的值变化。

七:查看主库的ip地址

image-20211016204339184

docker inspect --format='{{.NetworkSettings.IPAddress}}'  master-mysql1

八:进入Slave数据库

#
docker exec -it slave-mysql1 /bin/bash

# 进入MySQL
mysql -uroot -proot

# 执行同步脚本
change master to master_host='172.17.0.5', master_user='slave', master_password='123456', master_port=3306, master_log_file='mysql-bin.000001', master_log_pos=617, master_connect_retry=30;

参数解析

  • master_host :Master的地址
  • master_port:Master的端口号,指的是容器的端口号
  • master_user:用于数据同步的用户
  • master_password:用于同步的用户的密码
  • master_log_file:指定 Slave 从哪个日志文件开始复制数据,即上文中提到的 File 字段的值
  • master_log_pos:从哪个 Position 开始读,即上文中提到的 Position 字段的值
  • master_connect_retry:如果连接失败,重试的时间间隔,单位是秒,默认是60秒

九:查看Slave主从状态

# 在slave终端执行
show slave status \G;

image-20211016205352918

正常情况下,SlaveIORunning 和 SlaveSQLRunning 都是No,因为我们还没有开启主从复制过程。使用start slave;开启主从复制过程,然后再次查询主从同步状态show slave status \G;

image-20211016205444258

十:主从复制排错

mark

使用start slave开启主从复制过程后,如果SlaveIORunning一直是Connecting,则说明主从复制一直处于连接状态,这种情况一般是下面几种原因造成的,我们可以根据 Last_IO_Error提示予以排除。

  1. 网络不通

    检查ip,端口

  2. 密码不对

    检查是否创建用于同步的用户和用户密码是否正确

  3. pos不对

    检查Master的 Position

十一:测试主从复制

Master:

image-20211016205658635

Slave:

image-20211016205710222

以根据 Last_IO_Error提示予以排除。

  1. 网络不通

    检查ip,端口

  2. 密码不对

    检查是否创建用于同步的用户和用户密码是否正确

  3. pos不对

    检查Master的 Position

十一:测试主从复制

Master:
在这里插入图片描述

Slave:

在这里插入图片描述

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2021-10-17 12:20:35  更:2021-10-17 12:22:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 19:23:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码