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

news2024/12/28 22:20:29

系列文章

使用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.18
    ports:
      - "3306:3306"
    deploy:
      replicas: 1
    restart: always
    volumes:
      - ./mysql1/conf:/etc/mysql/conf.d
      - ./mysql1/data:/var/lib/mysql
      - ./mysql1/log:/var/log
    networks:
      - dbNetwork
    environment:
      - TZ=Asia/Shanghai
      - MYSQL_ROOT_PASSWORD=oracle
  mysql2:
    image: mysql:8.0.18
    ports:
      - "3307:3306"
    deploy:
      replicas: 1
    restart: always
    volumes:
      - ./mysql2/conf:/etc/mysql/conf.d
      - ./mysql2/data:/var/lib/mysql
      - ./mysql2/log:/var/log
    networks:
      - dbNetwork
    environment:
      - TZ=Asia/Shanghai
      - MYSQL_ROOT_PASSWORD=oracle
  mysql3:
    image: mysql:8.0.18
    ports:
      - "3308:3306"
    deploy:
      replicas: 1
    restart: always
    volumes:
      - ./mysql3/conf:/etc/mysql/conf.d
      - ./mysql3/data:/var/lib/mysql
      - ./mysql3/log:/var/log
    networks:
      - dbNetwork
    environment:
      - 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://www.coloradmin.cn/o/1935095.html

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

相关文章

FOG Project 文件名命令注入漏洞复现(CVE-2024-39914)

0x01 产品简介 FOG是一个开源的计算机镜像解决方案,旨在帮助管理员轻松地部署、维护和克隆大量计算机。FOG Project 提供了一套功能强大的工具,使用户能够快速部署操作系统、软件和配置设置到多台计算机上,从而节省时间和精力。该项目支持基于网络的 PXE 启动、镜像创建和还…

持续集成08--Jenkins邮箱发送构建信息及测试报告

前言 在持续集成&#xff08;CI&#xff09;和持续部署&#xff08;CD&#xff09;的自动化流程中&#xff0c;及时通知团队成员关于构建的成功或失败是至关重要的。Jenkins&#xff0c;作为强大的CI/CD工具&#xff0c;提供了多种通知机制&#xff0c;其中邮件通知是最常用且有…

<数据集>木材缺陷检测数据集<目标检测>

数据集格式&#xff1a;VOCYOLO格式 图片数量&#xff1a;4000张 标注数量(xml文件个数)&#xff1a;4000 标注数量(txt文件个数)&#xff1a;4000 标注类别数&#xff1a;8 标注类别名称&#xff1a;[Quartzity,Live_Knot,Marrow,resin,Dead_Knot,knot_with_crack,Knot_m…

Object和?

Class<?> 和 Class<Object> 是不同的。 Class<?> 是一个通配符类型&#xff0c;表示未知的具体类型&#xff0c;它可以匹配任意类型。例如&#xff0c;Class<?> 可以表示 String.class、Integer.class 或者任何其他类的 Class 对象。 Class<Ob…

哈喽GPT-4o,程序员如何通过GPT-4o保护自己的合法权益

目录 一、法律研究Prompt&#xff1a;派遣合同和劳务外包合同有什么区别&#xff1f;详细说一下在被裁员时的区别&#xff1f; 二、法律条文检索Prompt&#xff1a;检索《劳动合同法》&#xff0c;以下情况属于第几条&#xff0c;如果公司进行技能考试&#xff0c;并以技能考试…

HDLC(高级数据链路控制协议)的定义、数据结构、状态检测、基本配置、特点及限制

一、HDLC的定义 HDLC是一种面向比特的对用同步串行数字链路封装协议。 面向比特:对于任何比特流,HDLC都可以实现透明的传输; 同步串行:应用于同步串行线路; 应用于接口:在同步模式下的Serial接口和pos接口; 只支持点到点链路,通过keepalive报文来检测链路状态。 …

电脑屏幕录制怎么弄?分享3个简单的电脑录屏方法

在信息爆炸的时代&#xff0c;屏幕上的每一个画面都可能成为我们生活中不可或缺的记忆。作为一名年轻男性&#xff0c;我对于录屏软件的需求可以说是既挑剔又实际。今天&#xff0c;我就为大家分享一下我近期体验的三款录屏软件&#xff1a;福昕录屏大师、转转大师录屏大师和OB…

【sklearn | 7】:scikit-learn项目实战指南

引言 在数据科学和机器学习领域&#xff0c;Python以其简洁的语法和强大的库支持&#xff0c;成为了许多开发者和研究者的首选语言。而在众多Python机器学习库中&#xff0c;scikit-learn以其易用性、灵活性和强大的算法集合&#xff0c;成为了最受欢迎的库之一。本文将深入探…

【electron】 快速启动electron 应用

学无止境&#xff1a; 最近在搞electron项目&#xff0c;最重要的是总结 &#xff0c;写下来总不会忘记&#xff0c;也希望给大家参考一下&#xff0c;有不对的地方希望大家多指点。 快速启动electron 应用 1 克隆示例项目的仓库 git clone https://github.com/electron/ele…

如何用手机压缩视频?手机压缩视频方法来了

高清视频的大文件大小常常成为分享和存储的障碍&#xff0c;尤其是在数据流量有限或存储空间紧张的情况下。幸运的是&#xff0c;无论是智能手机还是个人电脑&#xff0c;都有多种方法可以帮助我们轻松压缩视频文件&#xff0c;以适应不同的需求和情境。本文将介绍如何在手机上…

【Apache Doris】周FAQ集锦:第 16 期

【Apache Doris】周FAQ集锦&#xff1a;第 16 期 SQL问题数据操作问题运维常见问题其它问题关于社区 欢迎查阅本周的 Apache Doris 社区 FAQ 栏目&#xff01; 在这个栏目中&#xff0c;每周将筛选社区反馈的热门问题和话题&#xff0c;重点回答并进行深入探讨。旨在为广大用户…

BI如何实现制造业精益生产可视化管理?

当前&#xff0c;制造业正快速向智能化和数字化转型。企业通过引入物联网、大数据、云计算和人工智能等技术&#xff0c;显著提升了生产过程的自动化和智能化水平。同时&#xff0c;工业4.0理念的普及&#xff0c;使得智能工厂和智能物流逐渐成为主流&#xff0c;帮助企业实现更…

C语言 | Leetcode C语言题解之第258题各位相加

题目&#xff1a; 题解&#xff1a; int addDigits(int num){while (num > 10) {int sum 0;while (num > 0) {sum num % 10;num / 10;}num sum;}return num; }

【人工智能大模型】文心一言介绍以及基本使用指令

目录 一、产品背景与技术基础 二、主要功能与特点 基本用法 指令的使用 注意事项 文心一言&#xff08;ERNIE Bot&#xff09;是百度基于其文心大模型技术推出的生成式AI产品。以下是对文心一言的详细介绍&#xff1a; 一、产品背景与技术基础 技术背景&#xff1a;百度…

LabVIEW和Alicat Scientific质量流量计实现精确流量控制

在现代工业自动化和科研实验中&#xff0c;精确的气体流量控制至关重要。这里将介绍一个使用LabVIEW与Alicat Scientific公司的质量流量计实现流量控制的项目。项目采用Alicat Scientific的质量流量计&#xff08;型号&#xff1a;M-200SCCM-D&#xff09;&#xff0c;通过LabV…

Python | Leetcode Python题解之第257题二叉树的所有路径

题目&#xff1a; 题解&#xff1a; class Solution:def binaryTreePaths(self, root: TreeNode) -> List[str]:paths list()if not root:return pathsnode_queue collections.deque([root])path_queue collections.deque([str(root.val)])while node_queue:node node_…

9.11和9.9哪个大?GPT-4o也翻车了

今天刷到了这个问题&#xff0c;心血来潮去问下chatgpt-4o&#xff0c;没想到疯狂翻车... 第一次问&#xff1a; GPT一开始给出了难绷的解答&#xff0c;让我想起了某短视频软件评论区里对某歌手节目排名的质疑哈哈哈哈哈 但是在接下来的进一步询问和回答中它反应过来了。 第…

功能测试与APPSCAN自动化测试结合的提高效率测试策略

背景 手工探索性测试&#xff08;Manual Exploratory Testing&#xff0c;简称MET&#xff09;是一种软件测试方法&#xff0c;它依赖于测试人员的直觉、经验和即兴发挥来探索应用程序或系统。与传统的脚本化测试相比&#xff0c;手工探索性测试不遵循固定的测试脚本&#xff0…

【总结】nginx源码编译安装报错./configure: error: SSL modules require the OpenSSL library.

问题现象 源码编译安装nginx时&#xff0c;执行./configure …… --with-http_ssl_module 命令安装https模块&#xff0c;需要用到openssl&#xff0c;由于机器缺少openssl库&#xff0c;报如下错误。 …… checking for openat(), fstatat() ... found checking for getaddr…

VS code配置docker远程连接

一 前置条件 1、本地已安装docker 2、服务端docker已配置Docker配置远程连接 二 VScode安装docker扩展 三 执行docker命令 1、切换到远程docker节点 docker context create remote-docker --docker "hosthttp://192.168.6.9:2375" 2、使用远程节点 docker cont…