上一篇 【centos 使用 docker 方式安装 mysql】 笔记中,我们在三个虚拟机中使用 docker 方式新建了三个 mysql 容器服务,那么我们这篇文章来记录下,如何在这三台机器中设置 mysql 的主从复制功能。其中111 服务器作为主节点,112 和 113 两个服务器作为两个从节点,复制 111 服务器 mysql 的数据,进行同步。

章节一:安装篇

一、设置主节点 111 服务器下mysql 的 my.cnf 文件

进入 mysql 的挂载目录 /mnt/mysql/config 文件夹,编辑 my.cnf 文件。vim /mnt/mysql/config/my.cnf,添加如下配置:

  • 其中 server-id=111 要保证唯一性,每个节点的该参数都要不同
  • binlog-do-db 参数,设置多个复制数据库时需要重复配置该参数,示例如下测代码块中所示
# 主从复制配置区
[mysqld]
server-id=111 # 主服务器唯一ID
log-bin=mysql-bin # 启用二进制日志
binlog-ignore-db=mysql # 设置不要复制的数据库(可设置多个)
binlog-ignore-db=information_schema
binlog-do-db=iotings-cloud # 设置需要复制的数据库
binlog-do-db=iotings-config # 设置需要复制的数据库
binlog-do-db=iotings-seata # 设置需要复制的数据库
binlog_format=STATEMENT # 设置logbin格式

二、设置两个从节点 112、113 服务器下mysql 的 my.cnf 文件

vim /mnt/mysql/config/my.cnf

分别编辑如下参数:

1、112服务器

# 主从复制配置区
[mysqld]
server-id=112 #从服务器唯一ID
relay-log=mysql-relay #启用中继日志

2、113服务器

# 主从复制配置区
[mysqld]
server-id=113 #从服务器唯一ID
relay-log=mysql-relay #启用中继日志

三、设置三个mysql服务的 auto.cnf 文件的 uuid 参数

vim /mnt/mysql/data/auto.cnf

除了 my.cnf 中的 server-id 不能重复外,auto.cnf 文件中的 uuid 参数也不能重复,因为112和113 虚拟机是根据 111 进行克隆的,所以后两个服务器的 mysql 容器的 uuid 参数是一样的,那么修改后两个 uuid 参数,注意,不要再新加字符串,只在原来 uuid 的基础之上修改某个字符串即可,否则 mysql 容器重启会失败,异常为 无法找到该 uuid 等信息

vim /mnt/mysql/data/auto.cnf
[auto]
server-uuid=e777435b-b90d-11ed-90c2-0242ac110002 # 举例:修改0002为0003,不可新增字符串

四、设置 主节点 的 slave 访问权限

# 进入 111服务器的主 mysql 容器内
docker exec -it mysql /bin/bash # 开启 mysql 命令模式
mysql -uroot -padmin123 # 创建 slave 访问权限
mysql> GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' IDENTIFIED BY 'admin123';
Query OK, 0 rows affected, 1 warning (0.00 sec) # 查看主 master 状态
mysql> show master status;
+------------------+----------+--------------+--------------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+--------------------------+-------------------+
| mysql-bin.000001 | 438 | nacos_db | mysql,information_schema | |
+------------------+----------+--------------+--------------------------+-------------------+
1 row in set (0.00 sec) 注:记住这里的 File 和 Position 两个参数,在从节点的配置中要用到

五、配置 从节点 的 mysql 属性

# 分别进入 112、113服务器的主 mysql 容器内
docker exec -it mysql /bin/bash # 开启 mysql 命令模式
mysql -uroot -padmin123 # 然后执行如下命令,创建复制的一些配置
CHANGE MASTER TO MASTER_HOST='192.168.0.111',
MASTER_USER='slave',
MASTER_PASSWORD='admin123',
MASTER_PORT=3306,
MASTER_LOG_FILE='mysql-bin.000002',MASTER_LOG_POS=438; #启动从服务器复制功能
start slave; #查看从服务器状态
show slave status \G 注意:如果需要停用slave,命令为:stop slave; 如果没有异常的话,那么主从复制就配置好了,在主节点进行表和数据的增删,那么从节点会根据日志信息进行数据的同步!

六、出现了从节点异常信息后,根据具体的异常进行具体的分析

(1)出现了 【Slave_SQL_Running: No】 的异常信息,那么我们来解决一下

方案一:(已亲测,可行)

1、先停掉 slave

mysql> stop slave;

2、跳过错误步数,后面步数可变

mysql> set global sql_slave_skip_counter=1;

3、再启动 slave

mysql> start slave;

4、查看同步状态

mysql> show slave status\G

解决方法二:(重新做主从,完全同步,未亲测)

1、先进入主库进行锁表,注意窗口不要关闭

mysql> flush table with read lock;

2、把数据进行备份

> mysqldump -uroot -p --opt -R 数据库 > /data/bak.sql

3、再新开个窗口,查看主数据库信息

mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000005 | 1158 | | | |
+------------------+----------+--------------+------------------+-------------------+

4、在从库上停止slave

mysql> stop slave;

5、导入备份的数据文件

mysql> source /data/bak.sql

6、重置同步

mysql> reset slave;

7、重新设置同步节点

mysql> CHANGE MASTER TO
MASTER_HOST='192.168.0.111',
MASTER_PORT=3306,
MASTER_USER='sync',
MASTER_PASSWORD='admin123',
MASTER_LOG_FILE='mysql-bin.000005', # 按照具体的主节点信息写该配置
MASTER_LOG_POS=1158; # 按照具体的主节点信息写该配置

注:host,port,user,password请根据你的主库设置相应修改,log_file和log_pos根据主库中master status相应修改。

8、开启slave

mysql> start slave;

9、查看slave状态

mysql> show slave status\G;

显示如下信息则表示正常

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

10、对主数据库解锁

mysql> unlock tables;

(2)出现了 【Slave_IO_Running: No】 的异常信息,在各个从库中执行如下代码,可恢复(已亲测,可用)

stop slave;
reset slave;
start slave;

FAQ:

1、F:当看到数据没有同步时,而且查看从库没有任何异常,是怎么回事呢?

A:可能是没有配置该库进行同步,检查下设置同步的表

参考信息:

https://www.cnblogs.com/NIAN2011/p/16637719.htmlhttps://cloud.tencent.com/developer/article/2145753

http://www.codebaoku.com/it-mysql/it-mysql-180748.html

章节二:运维篇

一、添加新的同步库

场景就是,在三个服务器正常的运行之下,需要新增一个需要同步的数据库,那么正常的流程是什么呢,如下:

  • 首先,在主库的服务器中,配置 my.cnf 文件,新增需要同步的数据库,此刻还不能新建库,重启 docker 中的 mysql 容器
  • 然后,在主库中新建第一步配置的数据库
  • 最后检查其他两个从库的同步状态
  • 那么以后的新增表、添加表数据或者删除表、库的动作,三个库都会同步执行

10. docker方式下的mysql设置主从复制(一主两从)的更多相关文章

  1. Linux 下的mysql+centos7+主从复制

    mysql+centos7+主从复制   MYSQL(mariadb) MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可.开发这个分支的原因之一是:甲骨文公 ...

  2. MySQL 主从复制一主两从环境配置实战

    MySQL 初始化 MySQL 主从复制是指数据可以从一个 MySQL 数据库服务器主节点复制到一个或多个从节点.MySQL 默认采用异步复制方式;从节点可以复制主数据库中的所有数据库或者特定的数据库 ...

  3. MySQL的主从复制+双主模式

    MySQL的主从复制 部署环境: MySQL master 192.168.40.21 MySQL slave  192.168.40.22 思路: 当主MySQL上进行数据上的操作或者变化时,主My ...

  4. 2018.10.31 Mac下的Mysql修改字符编码修改的问题总结

    今天在弄数据库的时候发现存入中文汉字变成了问号,Mac跟windows处理方式不一样. show variables like '%char%'; 查看当前mysql的编码格式 也就是默认编码格式 + ...

  5. windows命令行方式下打印和设置PATH变量

    点击开始菜单,运行=>cmd打印当前变量:echo %PATH%结果:C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;d:\PRO ...

  6. MySQL主从复制(一主两从)

       主库开启bin-log二进制日志功能,并建立slave账号,并授权从库连接主库,从库通过change master得到主库的相关同步信息, 然后连接主库进行验证,主库产生的新数据会导入到bin- ...

  7. mysql 设置自增主键id的起始值

    修改user表,主键自增从20000开始 alter table user AUTO_INCREMENT=20000;

  8. 完全分布式hadoop2.5.0安装 VMware下虚拟机centos6.4安装1主两从hadoop

    请跟我走,从零开始搭建hadoop2.5.0环境.总览第一步:搭建三台能不用密码shh的虚拟机.第二步,装jdk,解压hadoop文件,配置环境变量和xml文件.第三步,复制克隆两个slave机器.调 ...

  9. redis 主从复制(一主两从)

    一.环境基本信息 系统 centos7 版本 redis 5.0.7 只用了一台机器,ip:192.168.64.123 master端口 6379,从机 端口 6380.6381 二.redis目录 ...

  10. 在docker下运行mysql

    docker pull mysql 从镜像仓库中拉取mysql镜像. 运行镜像 到此mysql在docker容器下运行成功. 使用Navicat连接工具连接到mysql 经过以上步骤就完成了在dock ...

随机推荐

  1. Java:如何在PowerPoint幻灯片中创建散点图

    散点图是通过两组数据构成多个坐标点,考察坐标点的分布,判断两变量之间是否存在某种关联或总结坐标点的分布模式.散点图将序列显示为一组点,值由点在图表中的位置表示,类别由图表中的不同标记表示,通常用于比较 ...

  2. 别逛了,送你一份2023年Java核心篇JVM(虚拟机)面试题整理

    Java内存区域 说一下 JVM 的主要组成部分及其作用? JVM包含两个子系统和两个组件,两个子系统为Class loader(类装载).Execution engine(执行引擎):两个组件为Ru ...

  3. SELinux入门学习总结

    前言 安全增强型 Linux(Security-Enhanced Linux)简称 SELinux,它是一个 Linux 内核模块,也是 Linux 的一个安全子系统. SELinux 主要由美国国家 ...

  4. python医学病理图片svs装换

    SVS文件是什么? 最开始拿到SVS文件一脸懵逼的,这货长这样(在windows下可以用Aperio ImageScope这个开源软件打开): 我现在接触的这种图片的大小一般在60M-1.5G之间,可 ...

  5. .NET中使用Redis总结——2.项目实战

    接上篇.NET中使用Redis总结 -- 1.Redis搭建 看一些Redis相关资料,.NET 方面ServiceStack.Redis 用的比较多,就直接拿来用了. 在使用过程中经常过出现假死状态 ...

  6. 如何训练个人的ChatGpt4

    如何在自己的计算机上安装类似 ChatGPT 的个人 AI 并在没有互联网的情况下运行它 本文旨在为任何人安装此软件.最初它有一个视频,伴随着操作方法,但是事情变化很快,我的三次尝试只是推迟了我发表这 ...

  7. Go语言核心知识回顾(接口、Context、协程)

    温故而知新 接口 接口是一种共享边界,计算机系统的各个独立组件可以在这个共享边界上交换信息,在面向对象的编程语言,接口指的是相互独立的两个对象之间的交流方式,接口有如下好处: 隐藏细节: 对对象进行必 ...

  8. day05-优惠券秒杀01

    功能03-优惠券秒杀01 4.功能03-优惠券秒杀 4.1全局唯一ID 4.1.1全局ID生成器 每个店铺都可以发布优惠券: 当用户抢购时,就会生成订单,并保存到tb_voucher_order这张表 ...

  9. 【Docker】安装及部署

    一.Ubuntu使用apt安装Docker 官方安装文档:https://docs.docker.com/engine/install/ubuntu/ 1.准备安装环境 [root@Docker-Ub ...

  10. 试用「ChatGPT」几周之后

    冷静下来,不吹不黑. 01 最近半年,互联网一款现象级的应用诞生:「ChatGPT」: 其火爆的程度,不输前面的羊了个羊: 最初了解到ChatGPT还是春节的时候,但那时网上的测评还没引起足够的好奇心 ...