两台互通的服务器使用Docker部署一主两从MySQL8.0.35
文章目录
- 1. 使用Docker Overlay网络(需Swarm模式)
- 在服务器1(172.25.0.19)上:
- 在服务器2(172.25.0.20)上:
- 创建 `overlay` 网络(172.25.0.19):
- 2. 部署主节点
- 3. 部署从节点1
- 4. 部署从节点2
- 5. 配置主从复制
- 进入主节点容器:
- 在主节点上授权复制用户:
- 查看主节点状态:
- 进入从节点1容器:
- 在从节点1上配置复制:
- 进入从节点2容器:
- 在从节点2上配置复制:
- 6. 验证复制状态
1. 使用Docker Overlay网络(需Swarm模式)
首先,在两台服务器上创建一个 Docker 网络,确保容器可以通过该网络相互通信。
在服务器1(172.25.0.19)上:
# 在服务器1初始化Swarm
docker swarm init --advertise-addr 172.25.0.19# 执行后会输出类似以下内容:
Swarm initialized: current node (hw0h813f85fgoonyifc5lsvpx) is now a manager.To add a worker to this swarm, run the following command:docker swarm join --token SWMTKN-1-5jq69qtjwv9iod6hep02389p6lll2sa3grcp9xatnre15iwj33-7sr5tb2e9m28hbcztpe0qf5r3 172.25.0.19:2377To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.
在服务器2(172.25.0.20)上:
# 在服务器2加入Swarm
docker swarm join --token SWMTKN-1-5jq69qtjwv9iod6hep02389p6lll2sa3grcp9xatnre15iwj33-7sr5tb2e9m28hbcztpe0qf5r3 172.25.0.19:2377# 加入成功后,会显示:
This node joined a swarm as a worker.
创建 overlay 网络(172.25.0.19):
在 Swarm 初始化后,需要在 Swarm 管理节点(即服务器1)上创建可附加的 overlay 网络,使用 --attachable 参数:
# 创建overlay网络
docker network create -d overlay --attachable mysql-cluster
2. 部署主节点
在服务器1上部署 MySQL 主节点,并对外暴露端口。
docker run -d \--name mysql-master \--network mysql-cluster \-e MYSQL_ROOT_PASSWORD='8th3xY]:NA' \-e MYSQL_DATABASE=test \-e MYSQL_USER=replication \-e MYSQL_PASSWORD='@2X0wZY/rq' \-p 3307:3306 \mysql:8.0.35 \--server-id=1 \--log-bin=mysql-bin \--bind-address=0.0.0.0 # 允许所有IP连接
3. 部署从节点1
在服务器1上部署 MySQL 从节点1,不对外暴露端口。
docker run -d \--name mysql-slave1 \--network mysql-cluster \-e MYSQL_ROOT_PASSWORD='8th3xY]:NA' \-e MYSQL_DATABASE=test \-e MYSQL_USER=replication \-e MYSQL_PASSWORD='@2X0wZY/rq' \mysql:8.0.35 \--server-id=2 \--log-bin=mysql-bin
4. 部署从节点2
在服务器2上部署 MySQL 从节点2,不对外暴露端口。
docker run -d \--name mysql-slave2 \--network mysql-cluster \-e MYSQL_ROOT_PASSWORD='8th3xY]:NA' \-e MYSQL_DATABASE=test \-e MYSQL_USER=replication \-e MYSQL_PASSWORD='@2X0wZY/rq' \mysql:8.0.35 \--server-id=3 \--log-bin=mysql-bin
5. 配置主从复制
在主节点上配置从节点1和从节点2的复制。
进入主节点容器:
docker exec -it mysql-master mysql -uroot -p'8th3xY]:NA'
在主节点上授权复制用户:
GRANT REPLICATION SLAVE ON *.* TO 'replication'@'%';
FLUSH PRIVILEGES;
在主库上修改复制用户的认证插件为 mysql_native_password(5.7版本则不用执行此步骤):
ALTER USER 'replication'@'%' IDENTIFIED WITH mysql_native_password BY '@2X0wZY/rq';
FLUSH PRIVILEGES;
查看主节点状态:
mysql> SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000003 | 1007 | | | |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)
记录 File 和 Position 的值,稍后会在从节点上使用。
进入从节点1容器:
docker exec -it mysql-slave1 mysql -uroot -p'8th3xY]:NA'
在从节点1上配置复制:
CHANGE MASTER TOMASTER_HOST='mysql-master',MASTER_USER='replication',MASTER_PASSWORD='@2X0wZY/rq',MASTER_LOG_FILE='mysql-bin.000003',MASTER_LOG_POS=1007;
START SLAVE;
进入从节点2容器:
docker exec -it mysql-slave2 mysql -uroot -p'8th3xY]:NA'
在从节点2上配置复制:
CHANGE MASTER TOMASTER_HOST='mysql-master',MASTER_USER='replication',MASTER_PASSWORD='@2X0wZY/rq',MASTER_LOG_FILE='mysql-bin.000003',MASTER_LOG_POS=1007;
START SLAVE;
6. 验证复制状态
在从节点1和从节点2上执行以下命令,查看复制状态:
SHOW SLAVE STATUS\G
确保 Slave_IO_Running 和 Slave_SQL_Running 都为 Yes。
例如:
mysql> SHOW SLAVE STATUS\G
*************************** 1. row ***************************Slave_IO_State: Waiting for source to send eventMaster_Host: mysql-masterMaster_User: replicationMaster_Port: 3306Connect_Retry: 60Master_Log_File: mysql-bin.000003Read_Master_Log_Pos: 1007Relay_Log_File: acd704f632bf-relay-bin.000002Relay_Log_Pos: 326Relay_Master_Log_File: mysql-bin.000003Slave_IO_Running: YesSlave_SQL_Running: YesReplicate_Do_DB: Replicate_Ignore_DB: Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: Last_Errno: 0Last_Error: Skip_Counter: 0Exec_Master_Log_Pos: 1007Relay_Log_Space: 543Until_Condition: NoneUntil_Log_File: Until_Log_Pos: 0Master_SSL_Allowed: NoMaster_SSL_CA_File: Master_SSL_CA_Path: Master_SSL_Cert: Master_SSL_Cipher: Master_SSL_Key: Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: NoLast_IO_Errno: 0Last_IO_Error: Last_SQL_Errno: 0Last_SQL_Error: Replicate_Ignore_Server_Ids: Master_Server_Id: 1Master_UUID: dc75461f-f3e7-11ef-844a-02420a000202Master_Info_File: mysql.slave_master_infoSQL_Delay: 0SQL_Remaining_Delay: NULLSlave_SQL_Running_State: Replica has read all relay log; waiting for more updatesMaster_Retry_Count: 86400Master_Bind: Last_IO_Error_Timestamp: Last_SQL_Error_Timestamp: Master_SSL_Crl: Master_SSL_Crlpath: Retrieved_Gtid_Set: Executed_Gtid_Set: Auto_Position: 0Replicate_Rewrite_DB: Channel_Name: Master_TLS_Version: Master_public_key_path: Get_master_public_key: 0Network_Namespace:
1 row in set, 1 warning (0.00 sec)
相关文章:
两台互通的服务器使用Docker部署一主两从MySQL8.0.35
文章目录 1. 使用Docker Overlay网络(需Swarm模式)在服务器1(172.25.0.19)上:在服务器2(172.25.0.20)上:创建 overlay 网络(172.25.0.19): 2. 部署…...
Java23种设计模式案例
目录 一、概述 二、创建型模式 (Creational Patterns) 单例模式 (Singleton Pattern) 工厂方法模式 (Factory Method Pattern) 抽象工厂模式 (Abstract Factory Pattern) 建造者模式 (Builder Pattern) 原型模式 (Prototype Pattern) 三、结构型模式 (Structu…...
stm32hal库寻迹+蓝牙智能车(STM32F103C8T6)
简介: 这个小车的芯片是STM32F103C8T6,其他的芯片也可以照猫画虎,基本配置差不多,要注意的就是,管脚复用,管脚的特殊功能,(这点不用担心,hal库每个管脚的功能都会给你罗列,很方便的.)由于我做的比较简单,只是用到了几个简单外设.主要是由带霍尔编码器电机的车模,电机…...
JavaScript知识点4
1.解释一下这段JavaScript代码 var fruits ["Apple", "Orange", "Apple", "Mango"]; var a fruits.indexOf("Apple",-1); console.log("index"a); 输出的a值为-1,indexOf的第二个参数是-1…...
形式化数学编程在AI医疗中的探索路径分析
一、引言 1.1 研究背景与意义 在数字化时代,形式化数学编程和 AI 形式化医疗作为前沿领域,正逐渐改变着我们的生活和医疗模式。形式化数学编程是一种运用数学逻辑和严格的形式化语言来描述和验证程序的技术,它通过数学的精确性和逻辑性,确保程序的正确性和可靠性。在软件…...
QT 引入Quazip和Zlib源码工程到项目中,无需编译成库,跨平台,加密压缩,带有压缩进度
前言 最近在做项目时遇到一个需求,需要将升级的文件压缩成zip,再进行传输; 通过网络调研,有许多方式可以实现,例如QT私有模块的ZipReader、QZipWriter;或者第三方库zlib或者libzip或者quazip等࿱…...
Ubuntu 安装 Nginx并配置反向代理
Ubuntu版本:Ubuntu 24.04.2 LTS 一、安装Nginx 更新系统软件包 安装前需确保系统处于最新状态,避免依赖冲突 sudo apt update && sudo apt upgrade -y 安装Nginx主程序 Ubuntu官方仓库已包含稳定版Nginx,直接安装即可 sudo…...
GitHub SSH连接问题解决指南
🔍 GitHub SSH连接问题解决指南 问题描述 遇到错误:ssh: connect to host github.com port 22: Connection refused 说明您的网络环境无法访问GitHub的SSH端口22,常见原因: 防火墙/网络运营商限制(国内常见…...
C++ 跨平台的 GetCurrentThreadId() 获取当前线程ID实现
支持:C11 及早前标准库版本,而无需使用:std::this_thread::get_id()。 支持:NDK/ANDROID、Windows、Linux、MacOS X 等多个操作系统平台。 int64_t GetCurrentThreadId() noexcept { #if defined(_WIN32) || defined(_WIN64)retu…...
钉钉MAKE AI生态大会思考
1. 核心特性 1.1 底层模型开放 除原有模型通义千问外,新接入猎户星空、智普、MinMax、月之暗面、百川智能、零一万物。 1.2 AI搜索 AI搜索贯通企业和个人散落在各地的知识(聊天记录、文档、会议、日程、知识库、项目等),通过大模型对知识逻辑化,直接生成搜索的答案,并…...
SQL笔记#复杂查询
一、视图 1、视图和表 使用试图时会执行SELECT语句并创建一张临时表。视图中保存的是SELECT语句;表中保存的是实际数据。 2、创建视图的方法 CREATE VIEW 视图名称(<视图列名1>,<视图列名2>,……) AS <SELECT语句> CREATE VIEW ProductSum (prod…...
【Linux】基于UDP/TCP套接字编程与守护进程
目录 一、网路套接字编程 (一)基础概念 1、源IP地址与目的IP地址 2、端口号 3、TCP与UDP 4、网络字节序 (二)套接字编程接口 1、socket 常见API 2、sockaddr结构 (三)UDP套接字 1、UDP服务器创建…...
springboot 引入前端
前端 打包 npm run build vue.config.js 文件 publicPath 默认建议保持 / publicPath: ‘/’ 后端 目录 粘贴下面目录之一: src/main/resources/static/ src/main/resources/public/ 补充(用的少) server:servlet:context-path: /thirdAdm…...
RTSP/Onvif安防平台EasyNVR接入EasyNVS显示服务缺失的原因与解决方案
EasyNVS云管理平台具备强大的汇聚与管理功能,支持EasyGBS、EasyNVR等平台的接入,能够将接入的视频资源进行统一输出,提供远程可视化运维等管理功能,特别适合解决设备现场没有固定公网IP但仍需在公网直播的需求。 在某次用户现场部…...
算法系列之回溯算法
在计算机科学领域,算法是解决问题的核心。回溯算法作为一种经典的算法设计技巧,以其试错和回退的思想,在解决许多复杂问题时展现出强大的能力。本文将深入探讨回溯算法,包括其核心概念、实现步骤、代码示例以及适用场景࿰…...
Uniapp 小程序接口封装与使用
深入理解 Uniapp 小程序接口封装与使用 在 Uniapp 小程序开发中,接口请求是获取和交互数据的关键部分。合理地封装接口不仅能提高代码的可维护性,还能增强项目的健壮性。今天,我们就来详细探讨一下如何在 Uniapp 中进行接口封装、引入以及使…...
Harmony开发笔记(未完成)
一、感想 作为一名拥有11年经验的Android开发者,我亲历了Android从高速发展到如今面临“僧多粥少”的过程。技术的世界瞬息万变,没有一种技术能够让人依赖一辈子。去年初,我自学了鸿蒙系统,并顺利通过了鸿蒙官方的初级和高级认。…...
观成科技:海莲花“PerfSpyRAT”木马加密通信分析
1.概述 在2024年9月中旬至10月,东南亚APT组织“海莲花”通过GitHub发布开源安全工具项目,针对网络安全人员发起了定向攻击。通过对相关攻击活动进行分析,可以将其与一些海莲花的样本关联起来。这些样本的通信数据结构与海莲花此前使用的攻击…...
Spring Boot @Async 注解深度指南
Spring Boot Async 注解深度指南 一、核心使用要点 启用异步支持 必须在启动类或配置类添加 EnableAsync,否则异步不生效。 SpringBootApplication EnableAsync public class Application { ... }线程池配置 默认问题:Spring 默认使用 SimpleAsyncTaskEx…...
windows设置暂停更新时长
windows设置暂停更新时长 win11与win10修改注册表操作一致 ,系统界面不同 1.打开注册表 2.在以下路径 \HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings 右键新建 DWORD 32位值,名称为FlightSettingsMaxPauseDays 根据需求填写数…...
从防御者视角复盘:如果你的PHP代码像DVWA Low级一样写,会被黑客怎么‘爆’?
开发者必修课:当你的PHP代码沦为黑客的游乐场 想象一下这样的场景:你三年前写的PHP代码至今仍在线上运行,而某天突然发现数据库中的所有用户信息被黑客拖库。更可怕的是,攻击者利用的正是你当年随手写下的$id $_REQUEST[id];这样…...
LangFlow从安装到实战:可视化搭建多智能体应用完整教程
LangFlow从安装到实战:可视化搭建多智能体应用完整教程 1. LangFlow简介 LangFlow是一款革命性的低代码AI应用构建工具,它通过可视化界面让开发者能够像搭积木一样快速组合各种AI组件。无论你是想构建智能客服、文档分析系统还是多智能体协作应用&…...
造相-Z-Image效果展示:4090深度优化,中英文提示词直出惊艳作品
造相-Z-Image效果展示:4090深度优化,中英文提示词直出惊艳作品 你是否好奇,当顶级的RTX 4090显卡遇上专为它深度优化的文生图引擎,会产生怎样令人惊叹的作品?今天,我们不谈复杂的参数,不聊晦涩…...
SEU操作系统实践:从进程隐身到Shell构建的深度探索
1. 进程隐身:从原理到实战 第一次接触进程隐身这个概念时,我脑海中浮现的是科幻电影里的隐形战机。在Linux系统中,进程隐身同样神奇——它能让指定进程从系统监控工具中"消失"。这个实验不仅考验我们对进程管理的理解,…...
HunyuanVideo-Foley生成音频的后处理:使用专业软件进行混音与母带制作
HunyuanVideo-Foley生成音频的后处理:专业混音与母带制作全流程展示 1. 从AI生成到专业音效的蜕变之旅 当你第一次听到HunyuanVideo-Foley生成的原始音频时,可能会觉得它已经相当不错了。但如果你想要达到专业出版级的音质,还需要一些关键的…...
Pixel Couplet Gen惊艳案例:神荼郁垒像素方块+物理卷轴动态渲染
Pixel Couplet Gen惊艳案例:神荼郁垒像素方块物理卷轴动态渲染 1. 项目概览 当AI技术遇上复古游戏美学,Pixel Couplet Gen为我们带来了一场视觉与文化的盛宴。这款基于ModelScope大模型的春联生成器,彻底颠覆了传统春联的设计语言ÿ…...
抖音弹幕监听完整实战指南:基于系统代理的高效抓包技术解析
抖音弹幕监听完整实战指南:基于系统代理的高效抓包技术解析 【免费下载链接】DouyinBarrageGrab 基于系统代理的抖音弹幕wss抓取程序,能够获取所有数据来源,包括chrome,抖音直播伴侣等,可进行进程过滤 项目地址: htt…...
PDF-Extract-Kit-1.0与STM32CubeMX的嵌入式集成方案
PDF-Extract-Kit-1.0与STM32CubeMX的嵌入式集成方案 1. 工业现场的真实需求场景 在工厂自动化产线里,设备运行日志、维修手册、质检报告这些资料大多以PDF格式存在。操作员需要快速从几十页的技术文档中提取某个传感器的参数范围,或者从维修记录里找出…...
黑苹果触摸板手势终极方案:从卡顿到流畅的完整配置指南
黑苹果触摸板手势终极方案:从卡顿到流畅的完整配置指南 【免费下载链接】Hackintosh Hackintosh long-term maintenance model EFI and installation tutorial 项目地址: https://gitcode.com/gh_mirrors/ha/Hackintosh 还在为黑苹果触摸板的生硬操作而烦恼吗…...
FlowState Lab 模型架构可视化与核心模块解读
FlowState Lab 模型架构可视化与核心模块解读 1. 模型整体架构概览 FlowState Lab是一个专门针对复杂波动模式捕捉设计的深度学习模型。通过创新的架构设计,它在金融时间序列预测、物理系统模拟等领域展现出卓越性能。让我们先来看看它的整体架构图: 这…...
