使用docker部署mysql8.0实现主从复制

15 篇文章 0 订阅
9 篇文章 0 订阅

1. 建立mysql数据和配置文件目录,比如

  mkdir -p /opt/data/mysql/mysql-master/data /opt/data/mysql/mysql-master/conf
  mkdir -p /opt/data/mysql/mysql-slave/data  /opt/data/mysql/mysql-slave/conf

2. 分别在mysql-master和mysql-slave下的conf中创建my.cnf配置文件

mysql-master/conf/my.cnf

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

mysql-slave/my.cnf

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

3. 运行mysql容器

docker run -p 3310:3306 --name mysql8-master --restart=always --privileged=true -v /opt/data/mysql/mysql-master/conf:/etc/mysql/conf.d -v /opt/data/mysql/mysql-master/logs:/logs -v /opt/data/mysql/mysql-master/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:8.0.19

docker run -p 3311:3306 --name mysql8-slave --restart=always --privileged=true -v /opt/data/mysql/mysql-slave/conf:/etc/mysql/conf.d -v /opt/data/mysql/mysql-slave/logs:/logs -v /opt/data/mysql/mysql-slave/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:8.0.19

4. 分别进入这两个运行的容器,修改密码加密规则

docker exec -it 容器id /bin/bash

# 登录mysql
mysql -uroot -p123456

# 选择数据库
use mysql;

# 查看mysql用户
select host,user,plugin,authentication_string from mysql.user;

# 修改为mysql_native_password
alter user 'root'@'%' identified with mysql_native_password by '123456';
# 刷新权限
flush privileges;

5. 进入mysql-master容器,登录数据库,记录File和Position字段的值后面将会用到

show master status;

6. 查看mysql-master节点的ip

docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名称|容器id

6. 进入msql-slave容器,登录数据库,执行以下命令

change master to master_host='172.17.0.2', master_user='root', master_password='123456', master_port=3306, master_log_file='mysql-bin.000001', master_log_pos=1272, master_connect_retry=30;


# master_host mysql-master的ip
# master_user mysql-master用户名
# master_password mysql-master密码
# master_port mysql-master端口号
# master_log_file slave从哪个日志文件开始复制数据,即上文中提到的File字段的值
# master_log_pos  指定从哪个position开始读,即上文中提到的 Position 字段的值
# master_connect_retry 如果连接失败,重试的时间间隔,单位是秒,默认是60秒

7. 开启主从复制

start slave;

8. 查看状态

show slave status
# SlaveIORunning 和 SlaveSQLRunning 都是Yes,说明主从复制已经开启。此时可以测试数据同步是否成功。

9. 排查错误 

查看Last_IO_Error错误信息,可能某些数据库或表不存在,执行sql执行出错,需要手动跳过。

stop slave;
SET GLOBAL  SQL_SLAVE_SKIP_COUNTER=1;
start slave;

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值