Docker 容器 mysql 配置主从

1、前提条件

  • 集群的条件下 服务器 172.16.11.195 13316:3306 服务器 172.16.11.196 13317:3306
  • 配置好主数据库和从数据

2、配置主从数据库

2.1使用portainer 来管理容器

建立数据库密码

新增配置文件

XML 复制代码
# mysql-master.cnf
[mysqld]
server_id=110
log-bin=mysql-bin

relay_log=mysql-relay-bin
log_replica_updates=on
secure_file_priv=/var/lib/mysql
XML 复制代码
# mysql-slave.cnf
[mysqld]
server_id=111
log-bin=mysql-bin
slave-skip-errors=1032

read_only=1
relay_log=mysql-relay-bin
log_replica_updates=on
secure_file_priv=/var/lib/mysql
XML 复制代码
# eip-mysql-cluster
version: '3.7'
services:
  eip-mysql-master:
    image: harbor.hkc.cn/jpaas/mysql:8
    privileged: true
    hostname: eip-mysql-master    
    container_name: eip_mysql_master
    networks:
      - golbal-service-jpaas-net
    ports:
      - 13316:3306
    volumes:
      - /etc/localtime:/etc/localtime
      - mysql-master-data:/var/lib/mysql
    configs:
      - source: mysql-master.cnf
        target: /etc/mysql/my.cnf
    command:
      --default-authentication-plugin=mysql_native_password
      --max_connections=6000
      --character-set-server=utf8mb4
      --collation-server=utf8mb4_general_ci
      --explicit_defaults_for_timestamp=true
      --lower_case_table_names=1
      --default-time-zone='+8:00'
      --expire-logs-days=7
      --sql_mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"
    deploy:
      replicas: 1
      placement:
        constraints: [node.labels.zone == dbmaster]
      restart_policy:
        condition: on-failure
    secrets:
      - mysql-secrt
    environment:
      - MYSQL_ROOT_PASSWORD_FILE=/run/secrets/mysql-secrt
    
  eip-mysql-slave:
    image: harbor.hkc.cn/jpaas/mysql:8
    privileged: true
    hostname: eip-mysql-slave  
    container_name: eip_mysql_slave
    networks:
      - golbal-service-jpaas-net
    ports:
      - 13317:3306
    volumes:
      - mysql-slave-data:/var/lib/mysql
      - /etc/localtime:/etc/localtime
    configs:
      - source: mysql-slave.cnf
        target: /etc/mysql/my.cnf
    command:
      --default-authentication-plugin=mysql_native_password
      --max_connections=6000
      --character-set-server=utf8mb4
      --collation-server=utf8mb4_general_ci
      --explicit_defaults_for_timestamp=true
      --lower_case_table_names=1
      --default-time-zone='+8:00'
      --expire-logs-days=7
      --sql_mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"
    deploy:
      replicas: 1
      placement:
        constraints: [node.labels.zone == dbslave]
      restart_policy:
        condition: on-failure
    secrets:
      - mysql-secrt
    environment:
      - MYSQL_ROOT_PASSWORD_FILE=/run/secrets/mysql-secrt

secrets:
   mysql-secrt:
    external: true

configs:
  mysql-master.cnf:
    external: true
  mysql-slave.cnf:
    external: true
    
volumes:
  mysql-master-data:
  mysql-slave-data:
  
networks:
  golbal-service-jpaas-net:
       external: true

3、配置主从同步

3.1 配置主节点访问账号

进入容器里面的mysql

bash 复制代码
# 登录mysql 
mysql -uroot -ptryyiuer 

创建访问账户

bash 复制代码
## 创建从节点的访问账号
CREATE USER 'slave'@'%' IDENTIFIED BY 'slave';
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

## 查看用户
SELECT User, Host FROM mysql.user;


## 查看用户权限
SHOW GRANTS FOR 'slave'@'%';


## 查看master状态
show master status; 

这里记住 File 和 Position 这里属性的值。

退出mysql 执行 exit即可;

退出容器执行 exit即可;

3.2 配置从节点同步

如上一样,进入到从节点容器的mysql中。执行以下指令

bash 复制代码
# MASTER_HOST是互通的IP地址,如果是容器管理,加入同一个网络,使用容器的服务名称
# 端口默认3306  可以加上 Master_Port=3306  可以改成自己mysql 配置的端口
CHANGE MASTER TO
MASTER_HOST='eip-mysql-master',
MASTER_USER='slave',
MASTER_PASSWORD='slave',
MASTER_LOG_FILE='ON.000004',
MASTER_LOG_POS=7639;

## 执行完成后,开启同步
start slave;

## 查看状态(不需要分号)
SHOW SLAVE STATUS\G

两个关键进程:下面两个参数都是Yes,则说明主从配置成功!

4、测试

5、可能会出现的问题

4.1、数据库结构一致

  • 配置之前,一定要保证两个数据的结构一样

4.2、网络原因

  • 是否关闭防火墙。
bash 复制代码
# 查看防火墙状态
systemctl status firewalld.service

# 关闭防火墙
systemctl stop firewalld.service

# 开启防火墙
systemctl start firewalld.service

# 防火墙随系统开启启动
systemctl enable firewalld.service

# 执行开机禁用防火墙自启命令
systemctl disable firewalld.service
  • ping ip 是否连通。
bash 复制代码
ping 172.16.11.195

4.3、实在不行就:重置从服务器(重新配置)

bash 复制代码
# 如果上述方法都无法解决问题,或者从服务器的复制状态变得混乱,你可能需要重置从服务器的复制状态:
STOP SLAVE;
RESET SLAVE ALL;
相关推荐
指尖下的技术43 分钟前
Mysql面试题----MyISAM和InnoDB的区别
数据库·mysql
橘子在努力1 小时前
【橘子ES】使用docker搭建ELK环境
elk·elasticsearch·docker
元气满满的热码式1 小时前
K8S中ingress详解
云原生·容器·kubernetes
指尖下的技术2 小时前
Mysql面试题----为什么B+树比B树更适合实现数据库索引
数据结构·数据库·b树·mysql
Ciderw2 小时前
MySQL为什么使用B+树?B+树和B树的区别
c++·后端·b树·mysql·面试·golang·b+树
matrixlzp2 小时前
K8S 启动探测、就绪探测、存活探测
云原生·容器·kubernetes
Dusk_橙子2 小时前
在K8S中,如何使用EFK实现日志的统一管理?
云原生·容器·kubernetes
Tony11542 小时前
Kubernetes v1.28.0安装dashboard v2.6.1(k8s图形化操作界面)
云原生·容器·kubernetes
龙胖不下锅2 小时前
k8s资源预留
云原生·容器·kubernetes
超级阿飞2 小时前
利用Kubespray安装生产环境的k8s集群-排错篇
docker·容器·kubernetes