05 07 2021

Docker 搭建 MySQL 8.x 主从复制

1、拉取镜像

  1. docker pull mysql:latest

2、查看镜像

  1. docker images
  2. ————————————————————————————
  3. mysql latest c8562eaf9d81 5 months ago 546MB

3、创建启动容器

Master

  1. docker run -p 3306:3306 --name mysql-master -e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest

Slave

  1. docker run -p 3307:3306 --name mysql-slave -e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest

MySQL主数据库端口为3306,容器名称为mysql-master,默认密码为123456,-d为后台运行。

MySQL从数据库端口为3307,容器名称为mysql-slave,默认密码为123456,-d为后台运行。

4、配置Master

进入容器

  1. docker exec -it mysql-master /bin/bash

修改配置文件

  1. cd /etc/mysql
  2. vim my.cnf
  3. ————————————————————————————
  4. bash: vim: command not found

找不到vim命令解决

  1. # 更新包
  2. apt-get update
  3. # 安装vim
  4. apt-get install vim -y

修改配置文件,添加如下配置

  1. # 同一局域网内注意要唯一
  2. server-id=1
  3. # 开启二进制日志功能,二进制文件名称
  4. log-bin=master-bin
  5. # 二进制日志格式,有row、statement、mixed三种格式,row指的是把改变的内容复制过去,而不是把命令在从服务器上执行一遍,statement指的是在主服务器上执行的SQL语句,在从服务器上执行同样的语句。MySQL默认采用基于语句的复制,效率比较高。mixed指的是默认采用基于语句的复制,一旦发现基于语句的无法精确的复制时,就会采用基于行的复制。
  6. binlog-format=ROW
  7. # 同步的数据库名称,如果不配置,表示同步所有的库
  8. binlog-do-db=数据库名

重启容器

  1. docker restart mysql-master

5、配置Slave

进入容器

  1. docker exec -it mysql-slave /bin/bash

修改配置文件如下

  1. # 同一局域网内注意要唯一server-id=2# 开启二进制日志功能,二进制文件名称log-bin=slave-bin# 二进制文件的格式binlog-format=ROW

重启容器

  1. docker restart mysql-slave

6、开启Master-Slave主从复制

进入master容器或者通过MySQL客户端工具,执行 show master status 查看master状态,记录相关信息。

  1. mysql->show master status;
  2. ————————————————————————————
  3. +-------------------+----------+--------------+------------------+-------------------+
  4. | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
  5. +-------------------+----------+--------------+------------------+-------------------+
  6. | master-bin.000007 | 156 | | | |

查看master容器的独立IP

  1. docker inspect --format='{{.NetworkSettings.IPAddress}}' mysql-master
  2. ————————————————————————————
  3. 172.17.0.4

进入slave容器或者通过MySQL客户端工具,执行如下命令

  1. change master to master_host='172.17.0.4', master_user='root', master_password='123456', master_port=3306, master_log_file='master-bin.000007', master_log_pos=156, master_connect_retry=60;
  • master_host:master的容器独立IP
  • master_port:master的容器端口号
  • master_user:用于同步数据的用户
  • master_password:用于同步数据的用户密码
  • master_log_file:指定 Slave 从哪个日志文件开始复制数据,即上文中提到的 File 字段的值
  • master_log_pos:从哪个 Position 开始读,即上文中提到的 Position 字段的值
  • master_connect_retry:如果连接失败,重试的时间间隔,单位是秒,默认是60秒

启动Slave

  1. start slave

查看Slave状态

  1. show slave status \G;
  2. ————————————————————————————
  3. *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 172.17.0.4
  4. Master_User: root
  5. Master_Port: 3306
  6. Connect_Retry: 30
  7. Master_Log_File: master-bin.000007
  8. Read_Master_Log_Pos: 4187
  9. Relay_Log_File: a40ee670e244-relay-bin.000002 Relay_Log_Pos: 4356
  10. Relay_Master_Log_File: master-bin.000007
  11. Slave_IO_Running: Yes
  12. Slave_SQL_Running: Yes
  13. Replicate_Do_DB:
  14. Replicate_Ignore_DB:
  15. Replicate_Do_Table:
  16. Replicate_Ignore_Table:
  17. Replicate_Wild_Do_Table:
  18. Replicate_Wild_Ignore_Table:
  19. Last_Errno: 0
  20. Last_Error:
  21. Skip_Counter: 0
  22. Exec_Master_Log_Pos: 4187
  23. Relay_Log_Space: 4572
  24. Until_Condition: None
  25. Until_Log_File:
  26. Until_Log_Pos: 0
  27. Master_SSL_Allowed: No
  28. Master_SSL_CA_File:
  29. Master_SSL_CA_Path:
  30. Master_SSL_Cert:
  31. Master_SSL_Cipher:
  32. Master_SSL_Key:
  33. Seconds_Behind_Master: 0
  34. Master_SSL_Verify_Server_Cert: No
  35. Last_IO_Errno: 0
  36. Last_IO_Error:
  37. Last_SQL_Errno: 0
  38. Last_SQL_Error:
  39. Replicate_Ignore_Server_Ids:
  40. Master_Server_Id: 1
  41. Master_UUID: 77e35acb-bfb0-11eb-9513-0242ac110002
  42. Master_Info_File: mysql.slave_master_info
  43. SQL_Delay: 0
  44. SQL_Remaining_Delay: NULL
  45. Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates
  46. Master_Retry_Count: 86400
  47. Master_Bind:
  48. Last_IO_Error_Timestamp:
  49. Last_SQL_Error_Timestamp:
  50. Master_SSL_Crl:
  51. Master_SSL_Crlpath:
  52. Retrieved_Gtid_Set:
  53. Executed_Gtid_Set:
  54. Auto_Position: 0
  55. Replicate_Rewrite_DB:
  56. Channel_Name:
  57. Master_TLS_Version:
  58. Master_public_key_path:
  59. Get_master_public_key: 0
  60. Network_Namespace:

看到 Slave_IO_Running: Yes,Slave_SQL_Running: Yes 说明启动成功了。

7、关闭主从

进入slave容器mysql客户端

  1. stop slave;

8、主从测试

通过MySQL客户端自主创建数据库表…不展示了…

相关命令语法

拉取镜像
  1. docker pull {镜像名称}:{版本号(默认为latest)}
查看镜像
  1. docker images
创建启动容器
  1. docker run -p {对外暴露端口}:{容器内端口} --name {自定义容器名称} -e {参数} -d {镜像名称}:{版本号}
重启容器
  1. docker restart {容器id或者容器名称}
进入容器
  1. docker exec -it {容器id或者容器名称} /bin/bash
查看容器信息或指定信息
  1. docker inspect {容器id或者容器名称}
  2. docker inspect --format='{{.NetworkSettings.IPAddress}}' {容器id或者容器名称}
延伸阅读
  1. MySQL 5.7 详细安装步骤
  2. Linux下MySQL的彻底卸载
  3. 一文读懂 MySQL 事务
  4. MySQL 怎么解决幻读问题
  5. MySQL join的使用和原理
发表评论