docker 搭建mysql集群

docker 版本:Docker version 20.10.14, build a224086

使用win10系统

查看版本命令(docker -v

实现一主二从

准备

1、拉取镜像mysql-8.0

c:\>docker pull mysql:8.0

查看镜像

c:\>docker images

2、准备配置信息

  • 创建主配置目录和数据目录
D:/mysql8/master/cnf
D:/mysql8/master/data

D:/mysql8/slave1/cnf
D:/mysql8/slave1/data

D:/mysql8/slave2/cnf
D:/mysql8/slave2/data

配置

  • 主配置文件 mysql.cnf
[mysqld]
# 设置server_id,注意要唯一
server-id=1
# 开启binlog
log-bin=mysql-bin
# binlog缓存
binlog_cache_size=1M
# binlog格式(mixed、statement、row,默认格式是statement)
binlog_format=mixed
# 设置字符编码为utf8mb4
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'
[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4

放到 D:/mysql8/master/cnf里。

  • 1、2号从配置(除了server_id不同,其余都相同)
[mysqld]
# 设置server_id,注意要唯一
server-id=2
# 开启binlog
log-bin=mysql-slave-bin
# relay_log配置中继日志
relay_log=edu-mysql-relay-bin
# 如果需要同步函数或者存储过程
log_bin_trust_function_creators=false
# binlog缓存
binlog_cache_size=1M
# binlog格式(mixed、statement、row,默认格式是statement)
binlog_format=mixed
# 设置字符编码为utf8mb4
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'
slave_skip_errors=1062
[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4

分别放到D:/mysql8/slave1/cnfD:/mysql8/slave2/cnf里。

创建主从

  • ​创建一主两从
C:\>docker run -it -d -p 3307:3306 --name master -v d:/mysql8/master/cnf:/etc/mysql/conf.d -v d:/mysql8/master/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:8

C:\>docker run -it -d -p 3308:3306 --name slave1 -v d:/mysql8/slave1/cnf:/etc/mysql/conf.d -v d:/mysql8/slave1/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:8

C:\>docker run -it -d -p 3309:3306 --name slave2 -v d:/mysql8/slave2/cnf:/etc/mysql/conf.d -v d:/mysql8/slave2/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:8

-p 3307:3306 把物理机的3307端口与docker中的端口3306进行映射

-v 给容器挂载存储卷,挂载到容器的某个目录

-e MYSQL_ROOT_PASSWORD=123456 设置MySQL的root账号密码为123456

  • 查看是否创建成功

docker ps

  • 登录主服务器,创建用户
c:\> docker exec -it master /bin/bash
bash-4.4# mysql -uroot -p
mysql> show variables like 'mysql_id';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| server_id     | 2     |
+---------------+-------+

# 创建用户名:reader  密码:reader
mysql> CREATE USER reader IDENTIFIED BY 'reader';
Query OK, 0 rows affected (0.03 sec)
# 给reader同步权限
mysql> GRANT REPLICATION SLAVE ON *.* to 'reader'@'%';
Query OK, 0 rows affected (0.00 sec)
# 立即生效
mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.01 sec)
mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 |      157 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

# 再打开个控制台,查看master在docker中的地址
C:\>docker inspect --format='{{.NetworkSettings.IPAddress}}' master
'172.17.0.2'

如果出现:[Warning] World-writable config file '/etc/mysql/conf.d/mysql.cnf' is ignored.

登录docker容器后修改/etc/mysql/conf.d/mysql.cnf的权限chmod 664 mysql.conf

  • 登录从服务器
# 配置连接主服务器的参数
mysql> change master to master_host='172.17.0.2',master_user='reader',master_password='reader',master_log_file='mysql-bin.000001',master_log_pos=157;
# 启动同步
mysql> start slave;
Query OK, 0 rows affected, 1 warning (0.03 sec)
# 查看状态
mysql> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for source to send event
                  Master_Host: 172.17.0.2
                  Master_User: reader
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000001
          Read_Master_Log_Pos: 157
               Relay_Log_File: edu-mysql-relay-bin.000002
                Relay_Log_Pos: 326
        Relay_Master_Log_File: mysql-bin.000001
             Slave_IO_Running: Yes # 这个
            Slave_SQL_Running: Yes # 和这个都是Yes才算成功
              Replicate_Do_DB:
          Replicate_Ignore_DB:
           Replicate_Do_Table:
       Replicate_Ignore_Table:
      Replicate_Wild_Do_Table:
  Replicate_Wild_Ignore_Table:
                   Last_Errno: 0
                   Last_Error:
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 157
              Relay_Log_Space: 540
              Until_Condition: None
               Until_Log_File:
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_SSL_CA_File:
           Master_SSL_CA_Path:
              Master_SSL_Cert:
            Master_SSL_Cipher:
               Master_SSL_Key:
        Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error:
               Last_SQL_Errno: 0
               Last_SQL_Error:
  Replicate_Ignore_Server_Ids:
             Master_Server_Id: 1
                  Master_UUID: 11a8e0c8-030b-11ed-bbc9-0242ac110003
             Master_Info_File: mysql.slave_master_info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Replica has read all relay log; waiting for more updates
           Master_Retry_Count: 86400
                  Master_Bind:
      Last_IO_Error_Timestamp:
     Last_SQL_Error_Timestamp:
               Master_SSL_Crl:
           Master_SSL_Crlpath:
           Retrieved_Gtid_Set:
            Executed_Gtid_Set:
                Auto_Position: 0
         Replicate_Rewrite_DB:
                 Channel_Name:
           Master_TLS_Version:
       Master_public_key_path:
        Get_master_public_key: 0
            Network_Namespace:
1 row in set, 1 warning (0.00 sec)

没有成功的话,检查账号、密码、地址、pos等。

停止连接:mysql> stop slave;

在主服务器上查看结果

mysql> show slave hosts;
+-----------+------+------+-----------+--------------------------------------+
| Server_id | Host | Port | Master_id | Slave_UUID                           |
+-----------+------+------+-----------+--------------------------------------+
|         2 |      | 3306 |         1 | 56031934-030b-11ed-bc3c-0242ac110004 |
|         3 |      | 3306 |         1 | 9218281c-030b-11ed-bb85-0242ac110005 |
+-----------+------+------+-----------+--------------------------------------+

可能存在的问题:

mysql> start slave;
ERROR 1872 (HY000): Slave failed to initialize relay log info structure from the repository

解决办法:先执行 reset slave; 再执行start slave;

posted @ 2022-07-17 09:50  mantishell  阅读(790)  评论(0编辑  收藏  举报