主从复制是指将主数据库的DDL和DML操作通过二进制日志传到从库服务器,然后在从库上对这些日志重新执行(也叫重做),从而使得从库和主库的数据保持同步。
Mysql支持一台主库同时向多台从库进行复制,从库同时可以作为其他从服务器的主库,实现链状复制。
Mysql复制的优点主要包含以下三个方面:
主从复制,主要步骤如下:
我这里是通过docker镜像来搭建mysql主从服务,基础环境如下表所示:
软件 | 版本 | 描述 |
---|---|---|
docker desktop | 4.21.1 | docker容器桌面版 |
msyql:latest | oraclelinux/mysql-community-server-minimal 8.0.33 | mysql镜像 |
启动 Master和Slave容器
docker run -it -p 3309:3306 --name mysql8-master --privileged=true \
-v /Users/gaogzhen/data/docker/mysql/mysql8/node-master/conf/conf.d:/etc/mysql/conf.d \
-v /Users/gaogzhen/data/docker/mysql/mysql8/node-master/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql
docker run -it -p 3340:3306 --name mysql8-slave --privileged=true \
-v /Users/gaogzhen/data/docker/mysql/mysql8/node-slave/conf/conf.d:/etc/mysql/conf.d \
-v /Users/gaogzhen/data/docker/mysql/mysql8/node-slave/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql
使用docker desktop的话可以简单配置,不挂载配置和数据目录,直接同UI窗口修改;在linux服务器环境,建议挂载配置和数据目录,方便查看和修改。
不挂载直接进入容器修改式:
docker exec -it mysql8-master bash
cd /etc
vim my.cnf
[mysqld]
## 同一局域网内注意要唯一
server-id=100
## 开启二进制日志功能,可以随便取(关键)
log-bin=mysql-bin
配置完成之后,需要重启mysql服务使配置生效。使用service mysql restart完成重启。重启mysql服务时会使得docker容器停止,我们还需要docker start master启动容器。
Master数据库创建数据同步用户,授予用户 slave REPLICATION SLAVE权限和REPLICATION CLIENT权限,用于在主从库之间同步数据。
docker exec -it mysql8-master bash 进入到master容器中
mysql -u root -p
输入密码
CREATE USER ‘slave’@‘%’ IDENTIFIED BY ‘123456’;
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON . TO ‘slave’@‘%’;
这里我们通过修改挂载的配置目录,在conf.d下面新创建一个配置文件的方式来修改,不去修改my.cnf文件。
vim master.cnf
[mysqld]
## 同一局域网内注意要唯一
server-id=100
## 开启二进制日志功能,可以随便取(关键)
log-bin=mysql-bin
创建mysql用户和授权,可以直接本地执行如下命令
mysql -h127.0.0.1 -P3309 -uroot -p
步骤同上面相同,配置如下
[mysqld]
## 设置server_id,注意要唯一
server-id=101
## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
log-bin=mysql-slave-bin
## relay_log配置中继日志
relay_log=edu-mysql-relay-bin
配置完成之后,需要重启mysql服务使配置生效。使用service mysql restart完成重启。重启mysql服务时会使得docker容器停止,我们还需要docker start slave启动容器。
- 进入到mysql,mysql -u root -p
- show master status;
- 记录File(mysql-bin.000001), Position(157)
docker inspect --format='{{.NetworkSettings.IPAddress}}' mysql8-master
172.17.0.2
gaogzhen@gaogzhendeMacBook-Pro conf.d %
docker inspect --format='{{.NetworkSettings.IPAddress}}' mysql8-slave
172.17.0.3
进入Slave从库容器
master_port:Master的端口号,指的是容器的端口号
master_user:用于数据同步的用户
master_password:用于同步的用户的密码
master_log_file:指定 Slave 从哪个日志文件开始复制数据,即上文中提到的 File 字段的值
master_log_pos:从哪个 Position 开始读,即上文中提到的 Position 字段的值
master_connect_retry:如果连接失败,重试的时间间隔,单位是秒,默认是60秒
在Slave 中的mysql终端执行show slave status \G;用于查看主从同步状态
SlaveIORunning 和 SlaveSQLRunning 都是No
start slave开启主从复制
再次查询主从同步状态show slave status \G;
报错了
Last_IO_Error: Error connecting to source '[email protected]:3306'. This was attempt 1/86400, with a delay of 30 seconds between attempts. Message: Authentication plugin 'caching_sha2_password' reported error: Authentication requires secure connection.
Last_SQL_Errno: 0
解决方案在后面
- 在master创建一个test数据库,在slave中也会生成一个test数据库。
测试过程如下图所示:
在Master库做如下修改
ALTER USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
修改用户加密方式使用mysql_native_password
在修改了Master库之后,未重新设置关联配置
-- Master库
show master status;
-- Slave 库
stop slave;
change master to master_host='172.17.0.2', master_user='slave', master_password='123456', master_port=3306, master_log_file='mysql-bin.000003', master_log_pos= 440, master_connect_retry=30;
start slave;
如下图所示,状态正常
如果小伙伴什么问题或者指教,欢迎交流。
❓QQ:806797785
参考链接:
[1]MySQL数据库视频[CP/OL].2020-04-16.p158-162.
[2]mysql官网使用配置文件文档[CP/OL].
[3]基于docker搭建的mysql主从复制[CP/OL].
[4]Authentication plugin ‘caching_sha2_password’ cannot be loaded[CP/OL].