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

系列文章

使用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 <<EOF
[mysqld]
server-id=$i
user=mysql 
datadir=/var/lib/mysql
log-bin=mysql-bin 
relay-log=mysql-relay-bin 
gtid-mode=ON 
enforce-gtid-consistency=ON [mysql]
default-character-set=utf8 
EOF
done

在这里插入图片描述
这些配置文件都是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 <<EOF
version: "3"
services:mysql1:image: mysql:8.0.18ports:- "3306:3306"deploy:replicas: 1restart: alwaysvolumes:- ./mysql1/conf:/etc/mysql/conf.d- ./mysql1/data:/var/lib/mysql- ./mysql1/log:/var/lognetworks:- dbNetworkenvironment:- TZ=Asia/Shanghai- MYSQL_ROOT_PASSWORD=oraclemysql2:image: mysql:8.0.18ports:- "3307:3306"deploy:replicas: 1restart: alwaysvolumes:- ./mysql2/conf:/etc/mysql/conf.d- ./mysql2/data:/var/lib/mysql- ./mysql2/log:/var/lognetworks:- dbNetworkenvironment:- TZ=Asia/Shanghai- MYSQL_ROOT_PASSWORD=oraclemysql3:image: mysql:8.0.18ports:- "3308:3306"deploy:replicas: 1restart: alwaysvolumes:- ./mysql3/conf:/etc/mysql/conf.d- ./mysql3/data:/var/lib/mysql- ./mysql3/log:/var/lognetworks:- dbNetworkenvironment:- TZ=Asia/Shanghai- MYSQL_ROOT_PASSWORD=oracle
networks:dbNetwork:
EOF
  • 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:容器的名字

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3250121.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

记录一下在Hyper-v中动态磁盘在Ubuntu中不完全用到的问题(扩展根目录)

在之前给hyper虚拟机的Ubuntu分配磁盘有20G&#xff1b; 后来在Ubuntu中查看磁盘发现有一个分区没用到&#xff1a; 贴的图片是完成扩展后的 之前这里是10G&#xff0c;然后有个dev/sda4的分区&#xff0c;也是10G&#xff0c;Type是Microsoft Basic Data&#xff1b; …

实现了一个心理测试的小程序,微信小程序学习使用问题总结

1. 如何在跳转页面中传递参数 &#xff0c;在 onLoad 方法中通过 options 接收 2. radio 如何获取选中的值&#xff1f; bindchange 方法 参数e, e.detail.value 。 如果想要获取其他属性&#xff0c;使用data-xx 指定&#xff0c;然后 e.target.dataset.xx 获取。 3. 不刷…

项目实用linux 操作详解-轻松玩转linux

我之前写过完整的linux系统详解介绍&#xff1a; LInux操作详解一&#xff1a;vmware安装linux系统以及网络配置 LInux操作详解二&#xff1a;linux的目录结构 LInux操作详解三&#xff1a;linux实际操作及远程登录 LInux操作详解四&#xff1a;linux的vi和vim编辑器 LInux操作…

剧本杀小程序搭建,为商家带来新的收益方向

近几年&#xff0c;剧本杀游戏成为了游戏市场的一匹黑马&#xff0c;受到了不少年轻玩家的欢迎。随着信息技术的快速发展&#xff0c;传统的剧本杀门店已经无法满足游戏玩家日益增长的需求&#xff0c;因此&#xff0c;剧本杀市场开始向线上模式发展&#xff0c;实现行业数字化…

灵雀云AML:赋能金融AI,构建数智时代核心竞争力

在人工智能&#xff08;AI&#xff09;技术的迅猛发展中&#xff0c;金融行业正迈入变革的新时代。AI不仅在优化投资决策、信用评估、实时监控和欺诈识别方面展现出强大功能&#xff0c;还极大地提升了客户体验、降低了运营成本&#xff0c;并推动了产品创新。面对智能时代的挑…

唯众特色软件开发实训室解决方案

特色软件开发实训室解决方案旨在构建一个全方位、高度灵活且效率卓越的实训生态系统&#xff0c;它不仅仅是一个学习空间&#xff0c;更是一个让学生能够身临其境&#xff0c;在模拟真实工作环境中锤炼技能的实战场。通过精心设计的实训项目与案例&#xff0c;学生能够在实践中…

在Ubuntu上安装redis

Ubuntu上安装redis 一、通过下载redis的压缩包安装二、通过apt包管理器安装Redis三、修改redis的配置文件四、控制redis启动 Redis是一种开源的内存数据存储&#xff0c;可以用作数据库、缓存和消息代理等。本文将会介绍两种不同的安装方式&#xff0c;包括通过压缩包安装以及通…

日志之ELK使用讲解

文章目录 1 ELK1.1 ELK 简介1.1.1 Logstash1.1.2 Elasticsearch1.1.3 Kibana 1.2 ELK 实现方案1.3 ELK 平台搭建1.3.1 安装 Logstash1.3.2 安装 Elasticsearch1.3.3 安装 Kibana 1.4 在 SpringBoot 中使用 ELK1.4.1 修改并部署 Spring Boot 项目1.4.2 配置 Shipper 角色 Logsta…

国内从事双臂机器人的团队

一、背景 随着人形机器人的发展&#xff0c;双臂协同操作得到了越来越多研究人员的关注。我自己也是做双臂机器人方向的&#xff0c;虽然通过看论文或刷知乎了解到国内有许多团队在做双臂机器人方向&#xff0c;但还没有系统的整理过&#xff0c;因此趁这次机会&#xff0c;好…

【C++进阶学习】第七弹——AVL树——树形结构存储数据的经典模块

二叉搜索树&#xff1a;【C进阶学习】第五弹——二叉搜索树——二叉树进阶及set和map的铺垫-CSDN博客 目录 一、AVL树的概念 二、AVL树的原理与实现 AVL树的节点 AVL树的插入 AVL树的旋转 AVL树的打印 AVL树的检查 三、实现AVL树的完整代码 四、总结 前言&#xff1a…

前端轻松拿捏!最简全栈登录认证和权限设计!

本项目代码已开源&#xff0c;具体见&#xff1a; 前端工程&#xff1a;vue3-ts-blog-frontend 后端工程&#xff1a;express-blog-backend 数据库初始化脚本&#xff1a;关注公众号程序员白彬&#xff0c;回复关键字“博客数据库脚本”&#xff0c;即可获取。 前端走向全栈&am…

宋仕强谈狼性营销与五看三定

宋仕强说余承东董宇辉联合宣传&#xff0c;他们的狼性营销我们要学习&#xff0c;我们金航标和萨科微要认真学习华为的先进理念和成功经验&#xff0c;和“五看三定”思维和工作模型&#xff0c;让管理团队深度思考&#xff0c;再不断实践。在产品定义和市场定位方面&#xff0…

小程序js 把链接转换为二维码

GitHub - Rookie-M/weapp-qrcode: weapp.qrcode.js 在 微信小程序 中&#xff0c;快速生成二维码 1.要下载上面地址的插件包 2.引用 import drawQrcode from ../../utils/weapp.qrcode.minonLoad(options) {let that thisconsole.log(JSON.parse(options.info))that.setData…

Ubuntu 24.04 LTS 桌面安装MT4或MT5 (MetaTrader)教程

运行脚本即可在 Ubuntu 24.04 LTS Noble Linux 上轻松安装 MetaTrader 5 或 4 应用程序&#xff0c;使用 WineHQ 进行外汇交易。 MetaTrader 4 (MT4) 或 MetaTrader 5 是用于交易外汇对和商品的流行平台。它支持各种外汇经纪商、内置价格分析工具以及通过专家顾问 (EA) 进行自…

【BUG】已解决: KeyboardInterrupt

已解决&#xff1a; KeyboardInterrupt 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 欢迎来到我的主页&#xff0c;我是博主英杰&#xff0c;211科班出身&#xff0c;就职于医疗科技公司&#xff0c;热衷分享知识&#xff0c;武汉城市开发者社区主理人 擅长.net、C…

折叠屏遇上Galaxy AI,三星新一代Galaxy Z系列开启移动终端新篇章

作者 | 曾响铃 文 | 响铃说 随着换机周期的普遍延长以及智能手机行业内竞争态势的日益激烈&#xff0c;传统的硬件升级与参数比拼已难以全面满足消费者日益多元化的需求。面对这一挑战&#xff0c;行业迫切需要探索新的增长路径与发展方向。 折叠屏技术的兴起&#xff0c;无…

npm install时报错 reason: certificate has expired

在VS code中导入新项目&#xff0c;执行npm install时报错&#xff1a; npm warn old lockfile Could not fetch metadata for antv/g3.4.10 FetchError: request to https://registry.npm.taobao.org/antv%2fg failed, reason: certificate has expirednpm warn old lockfile …

用DrissionPage过某里滑块分析

最近我又在找工作了&#xff0c;悲哀啊~&#xff0c;面试官给了一道题&#xff0c;要求如下&#xff1a; 爬虫机试&#xff1a;https://detail.1688.com/offer/643272204627.html 过该链接的滑动验证码&#xff0c;拿到正确的商品信息页html&#xff0c;提取出商品维度的信息&a…

Notepad++换安装路径之后,右键打开方式报错:Windows无法访问指定设备、路径或文件。你可能没有适当的权限访问该项目。的处理方法

把Notepad添加到右键打开方式&#xff0c;可以参考下面的3篇文章添加&#xff1a; https://blog.csdn.net/xiaoerbuyu1233/article/details/88287747 https://blog.csdn.net/qq_44000337/article/details/120277317 https://www.cnblogs.com/zhrngM/p/12899026.html 这里主要是…

docker安装mysql突然无法远程连接

docker安装mysql突然莫名其妙的无法远程连接 docker安装mysql突然无法远程访问问题背景发现问题排查问题解决问题总结 docker安装mysql突然无法远程访问 问题背景 大概一年前在服务器中通过docker安装mysql5.7端口映射关系是3308->3306 前期在服务器上开方了3308端口 fir…