使用Docker 实现 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
..
) 可扩展成一个序列,例如:使得 {m..p}
扩展为 m n o pfor 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。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}
使用 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 是自定义的网络名称执行 docker compose up -d
命令创建三个 mysql 容器。
docker compose up -d
检查容器的运行时状态,注意容器名称与端口:
docker ps
CONTAINER ID
:容器的唯一标识符IMAGE
:容器所基于的镜像COMMAND
:容器启动时执行的命令CREATED
:容器创建的时间STATUS
:容器的状态,如是否正在运行PORTS
:容器暴露的端口NAMES
:容器的名字
上一篇:【Linux】服务器安装SSH
下一篇:CSS-1_0 CSS和文档流