使用Docker 实现 MySQL 循环复制(二)
创始人
2024-12-27 01:33:43
0

系列文章

使用Docker 实现 MySQL 循环复制(一)


目录

  • 系列文章
  • 1. 创建三个 mysql 容器
    • 1.1 准备三个 mysql 容器的挂载卷
    • 1.2 为三个mysql实例创建配置文件
    • 1.3 修改各目录的权限以满足 mysql 容器的要求
    • 1.4 创建 docker-compose.yaml 文件
    • 1.5 创建容器


1. 创建三个 mysql 容器

1.1 准备三个 mysql 容器的挂载卷

由于容器是运行时的,因此 mysql 容器的数据文件就必须映射到主机的磁盘以确保数据的持久化。

mkdir mysql-3 && cd mysql-3; mkdir -p mysql1/{conf,data,log}; for i in {2..3}; do cp -R mysql1 mysql$i; done 
  • 准备三个 mysql 容器的挂载卷,其中 conf 保存配置文件,data 是数据目录,log 保存日志文件。
  • 大括号扩展用于生成任意字符串
  • 双句点语法 (..) 可扩展成一个序列,例如:使得 {m..p} 扩展为 m n o p
    在这里插入图片描述

1.2 为三个mysql实例创建配置文件

for i in {1..3}; do  cat > mysql$i/conf/mysql.cnf <

在这里插入图片描述
这些配置文件都是MySQL服务器的主配置文件,用于指定服务器的行为和特性。

  • [mysqld]:这是MySQL服务器的主要配置块。
    • server-id=$i:这个参数定义了MySQL服务器的唯一ID。在复制环境中,每个服务器必须有一个唯一的ID。这里使用变量i来动态生成ID,从1到3。
    • user=mysql:这个参数指定了MySQL服务器运行时使用的用户。在这个例子中,用户是mysql。
    • datadir=/var/lib/mysql:这个参数指定了MySQL服务器的数据目录。所有的数据库文件都将保存在这里。
    • log-bin=mysql-bin:这个参数启用了二进制日志记录。二进制日志记录了对数据库的所有更改,对于复制非常重要。
    • relay-log=mysql-relay-bin:这个参数指定了中继日志的位置。中继日志用于记录从主服务器接收到的事件,以便在从服务器上重放。
    • gtid-mode=ON:这个参数启用了全局事务标识符(GTID)。GTID是一种自动分配给每个事务的唯一标识符,使得跟踪和管理复制变得更加容易。
    • enforce-gtid-consistency=0N:这个参数强制要求所有操作都保持GTID一致性。如果设置为ON,则所有操作都必须具有有效的GTID集,否则将被拒绝。
  • [mysql]:这是MySQL客户端的配置块。
    • default-character-set=utf8:这个参数设置了默认字符集为UTF-8。

1.3 修改各目录的权限以满足 mysql 容器的要求

chmod 0444 ./mysql{1..3}/conf/mysql.cnf  chmod 0777 ./mysql{1..3}/data chmod 0777 ./mysql{1..3}/log 

在这里插入图片描述

检查目录结构是否创建成功以及权限是否正确:

ls -ld mysql{1..3}/{conf/mysql.cnf,data,log} 

在这里插入图片描述

1.4 创建 docker-compose.yaml 文件

使用 docker compose 编排三个 mysql 容器,docker compose 是在独立服务器上的容器资源编排工
,对于大型分布式集群进行容器编排时就要使用 Kubernetes。docker compose 可以让我们通过一个 YAML 文件来定义和运行多个容器应用。

cat > docker-compose.yaml <
  • services:定义了三个服务,每个服务代表一个 MySQL 容器
  • ports::映射容器端口到主机端口,3307:3306 表示将容器内的 3306 端口映射到主机上的 3307 端口。这种映射方式可以让外部主机通过宿主机的 3307 端口访问到容器内的 MySQL 服务。避免了多个容器在同一台宿主机上使用相同的端口冲突
  • replicas: 1:设置副本数为 1,意味着只有一个实例。
  • volumes::挂载本地目录到容器内路径
  • networks::定义网络,dbNetwork 是自定义的网络名称

在这里插入图片描述
在这里插入图片描述

1.5 创建容器

执行 docker compose up -d 命令创建三个 mysql 容器。

docker compose up -d 

在这里插入图片描述

检查容器的运行时状态,注意容器名称与端口:

docker ps 

在这里插入图片描述

  • CONTAINER ID:容器的唯一标识符
  • IMAGE:容器所基于的镜像
  • COMMAND:容器启动时执行的命令
  • CREATED:容器创建的时间
  • STATUS:容器的状态,如是否正在运行
  • PORTS:容器暴露的端口
  • NAMES:容器的名字

相关内容

热门资讯

专业讨论!德扑之星真破解套路(... 专业讨论!德扑之星真破解套路(辅助挂)软件透明挂(有挂了解)-哔哩哔哩;人气非常高,ai更新快且高清...
每日必看!智星德州菠萝外挂检测... 每日必看!智星德州菠萝外挂检测(辅助挂)软件透明挂(有挂教学)-哔哩哔哩1、玩家可以在智星德州菠萝外...
透视透明挂!轰趴十三水有后台(... 轰趴十三水有后台赢率提升策略‌;透视透明挂!轰趴十三水有后台(辅助挂)软件透明挂(有挂详情)-哔哩哔...
发现玩家!德扑ai助手软件(辅... 发现玩家!德扑ai助手软件(辅助挂)透视辅助(有挂教学)-哔哩哔哩;玩家在德扑ai助手软件中需先进行...
一分钟了解!x-poker辅助... 一分钟了解!x-poker辅助软件(辅助挂)辅助透视(有挂攻略)-哔哩哔哩1、每一步都需要思考,不同...
一分钟揭秘!德州最新辅助器(辅... 一分钟揭秘!德州最新辅助器(辅助挂)透视辅助(有挂攻略)-哔哩哔哩;德州最新辅助器最新版本免费下载安...
玩家攻略推荐!德州辅助(辅助挂... 玩家攻略推荐!德州辅助(辅助挂)辅助透视(有挂了解)-哔哩哔哩是由北京得德州辅助黑科技有限公司精心研...
揭秘真相!pokernow德州... 《揭秘真相!pokernow德州(辅助挂)辅助透视(有挂介绍)-哔哩哔哩》 pokernow德州软件...
五分钟了解!德州之星辅助器(辅... 五分钟了解!德州之星辅助器(辅助挂)辅助透视(有挂透明)-哔哩哔哩1、很好的工具软件,可以解锁游戏的...
推荐一款!pokermaste... 1、推荐一款!pokermaster有外挂(辅助挂)透视辅助(有挂教学)-哔哩哔哩;详细教程。2、p...