当前位置: 首页 > article >正文

关系型数据库MySQL(三):主从复制

数据库主从复制一、主从复制核心概念定义主从复制是一种数据库架构模式允许一个 MySQL 数据库服务器主库将其数据变更自动复制到一个或多个其他 MySQL 服务器从库。目的高可用主库故障时从库可接管服务读写分离主库处理写操作从库处理读操作分担负载数据备份从库作为实时备份数据分析在从库运行分析任务避免影响主库性能二、主从复制工作原理理论核心MySQL 主从复制基于二进制日志Binary Log实现异步复制主库Master开启二进制日志binlog所有数据变更增删改会以“事件”形式记录到binlog从库连接主库后主库启动一个Binlog Dump 线程向从库发送binlog内容从库Slave开启中继日志relay logI/O 线程连接主库读取binlog并写入本地relay logSQL 线程读取relay log并重放其中的 SQL 事件实现数据同步关键点复制是异步的默认主库提交事务后立即返回不等待从库确认复制单位可以是语句Statement-Based或行Row-Based后者更可靠三、OpenEuler 环境准备运维实操1. 环境说明操作系统OpenEuler 22.03 LTSMySQL 版本8.0.26通过dnf安装服务器规划主库192.168.1.100从库192.168.1.1012. 安装 MySQL主从库相同# 安装MySQL Server sudo dnf install mysql-server # 启动服务并设置开机自启 sudo systemctl start mysqld sudo systemctl enable mysqld # 获取初始密码MySQL 8.0默认生成临时密码 sudo grep temporary password /var/log/mysqld.log3. 安全初始化主从库相同mysql_secure_installation # 根据提示设置root密码、移除测试库等四、主库配置192.168.1.1001. 修改配置文件/etc/my.cnf[mysqld] server-id 1 # 唯一ID主从不能重复 log-bin mysql-bin # 开启二进制日志 binlog-format ROW # 推荐使用ROW模式 expire_logs_days 7 # 自动清理7天前的日志 max_binlog_size 100M # 单个binlog文件大小 bind-address 0.0.0.0 # 允许所有IP连接生产环境建议限制2. 重启 MySQL 服务sudo systemctl restart mysqld3. 创建复制专用账户CREATE USER repl192.168.1.101 IDENTIFIED BY StrongPass!123; GRANT REPLICATION SLAVE ON *.* TO repl192.168.1.101; FLUSH PRIVILEGES;4. 锁定主库并获取状态信息FLUSH TABLES WITH READ LOCK; -- 锁定所有表禁止写入 SHOW MASTER STATUS; -- 记录File和Position值输出示例------------------------------------------------------------ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | ------------------------------------------------------------ | mysql-bin.000003 | 785 | | | ------------------------------------------------------------5. 备份主库数据可选若从库无数据mysqldump -u root -p --all-databases --master-data master_db.sql6. 解锁主库UNLOCK TABLES;五、从库配置192.168.1.1011. 修改配置文件/etc/my.cnf[mysqld] server-id 2 # 不同于主库 relay-log mysql-relay # 中继日志名称 read_only ON # 从库只读避免误写2. 重启 MySQL 服务sudo systemctl restart mysqld3. 导入主库备份若已备份mysql -u root -p master_db.sql4. 配置复制链路CHANGE MASTER TO MASTER_HOST192.168.1.100, MASTER_USERrepl, MASTER_PASSWORDStrongPass!123, MASTER_LOG_FILEmysql-bin.000003, -- 主库SHOW MASTER STATUS的值 MASTER_LOG_POS785; START SLAVE; -- 启动复制5. 检查复制状态SHOW SLAVE STATUS\G关键指标Slave_IO_Running: YesI/O线程正常Slave_SQL_Running: YesSQL线程正常Seconds_Behind_Master: 0无延迟六、故障排查与运维技巧1. 常见错误处理I/O 线程错误如网络不通STOP SLAVE; CHANGE MASTER TO ...; -- 重新配置 START SLAVE;SQL 线程错误如主键冲突STOP SLAVE; SET GLOBAL SQL_SLAVE_SKIP_COUNTER1; -- 跳过1个错误事件 START SLAVE;2. 延迟监控SHOW SLAVE STATUS\G # 关注 Seconds_Behind_Master3. 主从切换Failover停止主库写入提升从库为主库STOP SLAVE; RESET SLAVE; SET GLOBAL read_onlyOFF;修改应用连接指向新主库七、高级主题GTID 复制可选GTIDGlobal Transaction Identifier简化了复制管理# 主从库均需配置 [mysqld] gtid_modeON enforce_gtid_consistencyON配置命令CHANGE MASTER TO MASTER_AUTO_POSITION1; -- 自动定位同步点八、总结通过上述步骤你已在 OpenEuler 系统上成功搭建 MySQL 主从复制环境。关键要点原理基于 binlog 的异步复制配置server-id、log-bin、relay-log运维SHOW SLAVE STATUS监控、GTID 进阶附录常用命令速查-- 主库 SHOW MASTER STATUS; SHOW BINARY LOGS; -- 从库 SHOW SLAVE STATUS\G STOP SLAVE; START SLAVE; RESET SLAVE ALL; -- 彻底重置复制

相关文章:

关系型数据库MySQL(三):主从复制

数据库主从复制一、主从复制核心概念定义:主从复制是一种数据库架构模式,允许一个 MySQL 数据库服务器(主库)将其数据变更自动复制到一个或多个其他 MySQL 服务器(从库)。 目的:高可用&#xff…...

服务网格治理功能

服务网格治理功能:构建高效微服务架构的核心支柱 在云原生与微服务架构盛行的今天,服务网格(Service Mesh)已成为企业实现服务间通信、监控与安全的关键基础设施。而服务网格治理功能,则是其核心价值所在,…...

89C51定时器初值计算全攻略:12M与11.0592M晶振实战对照表

89C51定时器初值计算全攻略:12M与11.0592M晶振实战对照表 在嵌入式开发中,定时器的精确控制是许多功能实现的基础。对于使用89C51系列单片机的开发者来说,定时器初值的计算是一个必须掌握的技能。本文将深入探讨89C51定时器的工作原理&#x…...

用git bisect run自动化定位引入Bug的提交

在软件开发中,Bug的引入往往难以避免,尤其是当项目历史提交较多时,手动排查问题根源会变得异常耗时。Git提供的git bisect工具可以高效地定位引入Bug的提交。而结合git bisect run自动化脚本,开发者可以进一步减少人工干预&#x…...

百度网盘提取码智能解析工具:自动化获取解决方案

百度网盘提取码智能解析工具:自动化获取解决方案 【免费下载链接】baidupankey 项目地址: https://gitcode.com/gh_mirrors/ba/baidupankey 在数字资源分享日益频繁的今天,百度网盘作为国内主流的云存储平台,其提取码机制在保护资源的…...

LabVIEW堆叠柱状图实现

​LabVIEW 实现故障类型堆叠柱状图可视化,将字符串格式的原始数据转换为数值,通过嵌套循环计算各站点故障类型的累计百分比,经数组转置后,用波形图展示不同站点的故障占比分布,直观呈现各类故障在各站点的构成情况。程…...

如何用baidu-wangpan-parse轻松实现百度网盘高速下载

如何用baidu-wangpan-parse轻松实现百度网盘高速下载 【免费下载链接】baidu-wangpan-parse 获取百度网盘分享文件的下载地址 项目地址: https://gitcode.com/gh_mirrors/ba/baidu-wangpan-parse 在云存储时代,百度网盘已成为国内用户分享大型文件的首选平台…...

Pixel Language Portal入门指南:理解混元转码核心与跨维度语义保持机制

Pixel Language Portal入门指南:理解混元转码核心与跨维度语义保持机制 1. 产品概览 Pixel Language Portal(像素语言跨维传送门)是一款革命性的语言翻译工具,它重新定义了人机交互的翻译体验。基于腾讯Hunyuan-MT-7B核心引擎构…...

A级数据中心建设运营汇报方案:A级数据中心建设、A级数据中心运营、数据中心节能

该方案系统性地展示了A级数据中心从建设施工、组织管理、物资调配、测试培训到运维管理、故障处理,再到节能降耗(PUE优化)的全流程能力。重点突出了标准化建设、专业化分工、系统化调试、智能化运维和绿色节能目标的实现路径,适用…...

AI 大模型应用程序的开发

开发 AI 大模型应用程序(LLM Application)已经从简单的“API 调用”演变为一套复杂的工程化流程。目前的开发范式不再仅仅关注模型本身,而更侧重于如何将模型整合进业务逻辑中,并确保其产出的稳定性和准确性。以下是 AI 大模型应用…...

SAP Fiori SPA开发入门:从零搭建你的第一个企业级应用

1. 为什么选择SAP Fiori开发企业级应用? 如果你正在寻找一种高效开发企业级应用的方式,SAP Fiori绝对值得考虑。作为SAP官方推出的用户体验设计语言和开发框架,它专为企业应用场景优化,提供了开箱即用的丰富UI组件和标准化设计规范…...

1575M频段天线模块方案选型及物联网应用指南解析

随着全球通信技术的迅猛发展,频段天线模块在各类应用中扮演了重要角色,尤其是1575M频段天线模块,广泛应用于导航、定位、自动驾驶等领域。本文围绕1575M频段天线模块,从品牌厂商、优势产品、应用方案、选购要点及常见问题等方面进…...

AI 智能体的开发流程

开发一个成熟的 AI 智能体(AI Agent)不再是简单的“写提示词”,而是一个涉及工程化、数据闭环和持续评估的系统过程。以下是 2026 年主流的 AI Agent 开发标准流程。1. 需求定义与场景拆解在动手写代码前,必须明确 Agent 的边界。…...

技术整合的方法论与系统融合

技术整合的方法论与系统融合:构建高效协同的数字化未来 在数字化转型的浪潮中,技术整合与系统融合成为企业提升效率、实现创新的核心路径。技术整合并非简单堆砌工具,而是通过系统化方法论,将异构技术、数据与业务流程无缝衔接&a…...

CATIA高效设计:自定义快捷键全攻略

1. 为什么你需要自定义CATIA快捷键? 刚接触CATIA时,我和大多数人一样傻傻地用鼠标点菜单栏。直到有次看到同事用键盘噼里啪啦操作,建模速度比我快三倍,才意识到快捷键的重要性。CATIA默认的快捷键设置其实非常基础,很…...

保姆级教程:大麦DW22D路由器免拆机刷Breed和OpenWrt(附全套工具包)

大麦DW22D路由器零基础刷机指南:从入门到精通 第一次接触路由器刷机时,我盯着那些命令行界面和陌生的术语,感觉像是在看天书。直到亲手把一台闲置的大麦DW22D刷成了功能强大的OpenWrt系统,才发现原来整个过程可以如此简单——只要…...

别再手动分桶了!用torch.compile的dynamic模式,让PyTorch推理自动适应动态输入形状

动态输入形状的终极解决方案:torch.compile(dynamicTrue)深度解析 在深度学习推理场景中,输入数据的形状变化一直是工程优化的痛点。想象一下这样的场景:你的推荐系统需要处理从32到1024不等的用户行为序列,或者NLP模型要适应不同…...

用Quartus和Modelsim手把手教你:一个FPGA自动售货机的完整状态机设计(附Verilog代码)

从零构建FPGA自动售货机:状态机设计与Verilog实战指南 1. 项目概述与设计思路 想象一下,你正站在一台自动售货机前,准备购买一瓶饮料。这个看似简单的交互过程背后,隐藏着一套精密的状态控制系统。今天,我们将用FPGA和…...

Qwen3多模态进阶:结合图像描述生成更具上下文感的视频字幕

Qwen3多模态进阶:结合图像描述生成更具上下文感的视频字幕 不知道你有没有过这样的体验:看视频时,字幕只是机械地复述着台词,而画面里那些关键的动作、表情、场景变化,字幕却只字不提。比如,主角激动地举起…...

Android虚拟定位终极指南:FakeLocation如何解决你的位置隐私痛点

Android虚拟定位终极指南:FakeLocation如何解决你的位置隐私痛点 【免费下载链接】FakeLocation Xposed module to mock locations per app. 项目地址: https://gitcode.com/gh_mirrors/fak/FakeLocation 你是否曾因应用强制获取位置权限而感到不安&#xff…...

AI小白入门指南:30天掌握核心技能

学习人工智能(AI)是一个循序渐进的过程,尤其对新人小白来说,建议按照以下步骤逐步深入: 1. 打好基础 数学基础: AI的核心依赖数学知识,重点掌握: 线性代数:矩阵运算&…...

PyQt6开发教程(四):布局管理

案例:利用QtDesigner设计如下布局,如图1所示。图1一,布局管理分析布局即控件摆放的方式,如图2所示,在Qt Designer左侧的“布局”栏中可以看到有4种布局方式:“Vertical Layout(垂直布局&#xf…...

Poppler for Windows:让PDF处理变得简单的终极指南

Poppler for Windows:让PDF处理变得简单的终极指南 【免费下载链接】poppler-windows Download Poppler binaries packaged for Windows with dependencies 项目地址: https://gitcode.com/gh_mirrors/po/poppler-windows 还在为Windows上的PDF处理工具烦恼吗…...

从Java到Vue:一名全栈开发者的面试实录

从Java到Vue:一名全栈开发者的面试实录 面试官:你好,我是这次的面试官。请简单介绍一下你自己。 应聘者:你好,我叫林浩,25岁,毕业于上海交通大学计算机科学与技术专业,硕士学历。工作…...

学Simulink——基于Simulink的开关电容变换器电压均衡控制

目录 手把手教你学Simulink——基于Simulink的开关电容变换器电压均衡控制​ 摘要​ 一、背景与挑战​ 1.1 为什么需要主动电压均衡?​ 1.2 开关电容变换器(SCC):能量的“摆渡车”​ 1.3 破局之道:闭环电压均衡控制​ 二、系统架构与核心控制推导​ 2.1 整体架构:…...

CefFlashBrowser:2024年Flash内容终极解决方案,让经典游戏和课件重获新生

CefFlashBrowser:2024年Flash内容终极解决方案,让经典游戏和课件重获新生 【免费下载链接】CefFlashBrowser Flash浏览器 / Flash Browser 项目地址: https://gitcode.com/gh_mirrors/ce/CefFlashBrowser 在2024年的今天,你是否还在为…...

Phi-4-mini-reasoning GPU利用率提升:vLLM动态批处理与显存复用实测

Phi-4-mini-reasoning GPU利用率提升:vLLM动态批处理与显存复用实测 1. 模型简介与部署验证 Phi-4-mini-reasoning 是一个基于合成数据构建的轻量级开源模型,专注于高质量、密集推理的数据,并进一步微调以提高更高级的数学推理能力。该模型…...

学Simulink——基于Simulink的开关电容变换器电压均衡控制​

目录 手把手教你学Simulink——基于Simulink的开关电容变换器电压均衡控制​ 摘要​ 一、背景与挑战​ 1.1 为什么需要主动电压均衡?​ 1.2 开关电容变换器(SCC):能量的“摆渡车”​ 1.3 破局之道:闭环电压均衡控制​ 二、系统架构与核心控制推导​ 2.1 整体架构:…...

专业的装修门窗避坑服务商

装修时,门窗是影响居住体验的关键一环。选错了,不仅隔音差、漏风漏水,后期维修更是麻烦不断。面对市场上琳琅满目的品牌和五花八门的宣传,普通消费者该如何辨别,找到真正专业、省心的服务商?今天&#xff0…...

C# StreamReader/StreamWriter实战:5个真实场景下的高效文本处理技巧

C# StreamReader/StreamWriter实战:5个真实场景下的高效文本处理技巧 在数据处理的世界里,文本文件就像数字时代的纸张,承载着从配置信息到海量日志的各种关键数据。作为C#开发者,我们每天都要与这些文本文件打交道,而…...