mysql数据库中主从复制如何工作

主从复制通过二进制日志实现数据同步,主库记录变更,从库通过IO线程获取日志写入中继日志,SQL线程重放事件完成同步;需配置log-bin、复制账号及CHANGE MASTER TO等步骤,支持SBR、RBR和混合模式,可通过SHOW SLAVE STATUS监控状态并处理延迟或错误。

mysql数据库中主从复制如何工作

MySQL 主从复制是一种常见的数据同步机制,它允许一台数据库服务器(主库)的数据自动复制到另一台或多台数据库服务器(从库)。这个过程是异步的,不需要持续的网络连接,适用于高可用、读写分离和数据备份等场景。

主从复制的基本工作原理

主从复制的核心是通过日志来传递和重放数据变更。整个过程主要依赖于三种日志或线程:

二进制日志(Binary Log):主库记录所有更改数据的SQL语句或行变化(如 INSERT、UPDATE、DELETE)。 IO线程(在从库上):负责连接主库,请求并接收主库的二进制日志内容,写入到本地的中继日志(Relay Log)中。 SQL线程(在从库上):读取中继日志中的事件,并在从库上重新执行,从而实现数据同步。

整个流程如下:

主库每执行一个修改数据的事务,都会被记录到二进制日志文件中。 从库启动时,会创建一个IO线程,连接主库并请求从指定位置开始读取二进制日志。 主库启动一个 dump 线程,将日志内容发送给从库。 从库的 IO 线程接收到这些日志事件后,写入自己的中继日志文件。 从库的 SQL 线程读取中继日志中的事件,按顺序执行,使数据与主库保持一致。

配置主从复制的关键步骤

要搭建主从复制环境,需完成以下基本配置:

启用主库的二进制日志:在主库的 my.cnf 配置文件中设置 log-bin 和 server-id。 为从库创建复制账号:在主库上创建一个用于复制的用户,并授予 REPLICATION SLAVE 权限。 获取主库当前日志位置:通过 SHOW MASTER STATUS 获取当前二进制日志文件名和位置,供从库初始化使用。 配置从库信息:使用 CHANGE MASTER TO 命令指定主库的IP、端口、复制用户、密码以及日志文件和位置。 启动复制:运行 START SLAVE 后,从库开始同步数据。

主从复制的常见模式

MySQL 支持多种复制格式,影响日志记录方式和复制行为:

基于语句的复制(Statement-Based Replication, SBR):记录SQL语句本身。优点是日志量小,但某些非确定性函数可能导致主从数据不一致。 基于行的复制(Row-Based Replication, RBR):记录每一行数据的变化。更安全,适合复杂操作,但日志体积较大。 混合模式(Mixed):MySQL 自动选择使用语句还是行复制,兼顾效率与安全。

监控与故障处理

可以通过命令 SHOW SLAVE STATUSG 查看复制状态。重点关注:

Slave_IO_Running:是否正常拉取日志。 Slave_SQL_Running:是否正常执行日志。 Last_Error:最近的错误信息。 Seconds_Behind_Master:从库延迟时间。

如果出现错误,比如主键冲突或语句执行失败,可以尝试跳过错误事务(SET GLOBAL sql_slave_skip_counter),但需谨慎操作,避免数据不一致。

基本上就这些。主从复制机制虽然强大,但需要合理配置和持续监控,才能确保数据的一致性和系统的稳定性。

以上就是mysql数据库中主从复制如何工作的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/4626.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
文心一言官方网站直达地址 文心一言智能创作主页官方入口链接
上一篇 2025年11月3日 23:08:52
中用科技工业安全平台入选省重点平台
下一篇 2025年11月3日 23:10:07

相关推荐

  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Golang goroutine与channel调试技巧

    使用go run -race检测数据竞争,结合runtime.NumGoroutine监控协程数量,通过pprof分析阻塞调用栈,利用select超时避免永久阻塞,有效排查goroutine泄漏、死锁和数据竞争问题。 Go语言的goroutine和channel是并发编程的核心,但它们也带来了调试上…

    2026年5月10日
    000
  • 深入理解 Express.js 中 next() 参数的作用与中间件机制

    本文深入探讨 express.js 中间件函数中的 `next()` 参数。它负责将控制权传递给请求-响应周期中的下一个中间件或路由处理程序。文章将详细解释 `next()` 的工作原理、中间件的注册与执行顺序,以及不正确使用 `next()` 可能导致请求挂起的风险,并通过代码示例和实际应用场景,…

    2026年5月10日
    000
  • c++如何实现UDP通信_c++基于UDP的网络通信示例

    UDP通信基于套接字实现,适用于实时性要求高的场景。1. 流程包括创建套接字、绑定地址(接收方)、发送(sendto)与接收(recvfrom)数据、关闭套接字;2. 服务端监听指定端口,接收客户端消息并回传;3. 客户端发送消息至服务端并接收响应;4. 跨平台需处理Winsock初始化与库链接,编…

    2026年5月10日
    000
  • MySQL数据库不支持中文的解决办法

    接上一篇文章,在解决了mysql+flask环境配置问题之后,往数据库存中文字符串会报1366错误,提示不正确的字符。继而发现默认的mysql采用了latin1字符集,这种编码是不支持中文的。 如果想支持中文的话,需要设置一下mysql字符集。 众所周知utf-8是可以的,gbk也没问题,为了可扩展…

    用户投稿 2026年5月10日
    000
  • HTML表单如何实现PWA支持?怎样添加离线功能?

    答案是利用Service Worker缓存资源并结合Background Sync API实现离线提交与自动同步。通过注册Service Worker缓存表单相关文件,拦截提交行为,将离线数据存入IndexedDB,并注册后台同步任务,待网络恢复后由Service Worker自动发送数据,确保提交…

    2026年5月10日
    000
  • CodeIgniter在IIS环境下实现URL重写与index.php移除指南

    本教程详细指导如何在IIS服务器上部署的CodeIgniter应用中,移除URL中不必要的index.php。核心解决方案涉及修改CodeIgniter的config.php文件,将$config[‘index_page’]设置为空,并辅以正确的IIS web.config重…

    2026年5月10日
    100
  • Go语言连接外部MySQL数据库:DSN配置与常见错误解析

    本文详细阐述了go语言使用`go-sql-driver/mysql`驱动连接外部mysql数据库的正确方法。重点介绍了数据源名称(dsn)的规范格式,特别是主机地址部分的配置,以避免常见的“getaddrinfow: the specified class was not found.”等网络解析错…

    2026年5月10日
    000
  • C#如何进行网络编程?Socket与TCP/IP通信编程实例详解

    C#通过Socket类实现TCP通信,首先服务器绑定IP和端口并监听,客户端发起连接,双方通过Send/Receive收发数据,最后关闭连接。 C# 进行网络编程主要依赖于 System.Net 和 System.Net.Sockets 命名空间,其中最核心的是使用 Socket 类实现基于 TCP…

    2026年5月10日
    000
  • Go API 文档利器:godoc 的实践与应用

    `godoc` 是 go 语言官方提供的强大工具,能将符合规范的注释自动转换为专业且易于导航的 api 文档,其风格与 go 官网一致。本文将详细指导如何利用 `godoc` 在本地生成并浏览您的 go 项目文档,解决常见配置问题,助您高效展示代码api。 1. godoc 简介与 Go 注释规范 …

    2026年5月10日
    000
  • C++ 并发编程中内存访问问题及解决方法?

    在 c++++ 并发编程中,共享内存访问问题包括数据竞争、死锁和饥饿。解决方案有:原子操作:确保对共享数据的访问是原子性的。互斥锁:一次只允许一个线程访问临界区。条件变量:线程等待某个条件满足。读写锁:允许多个线程并发读取,但只能允许一个线程写入。 C++ 并发编程中的内存访问问题及解决方案 在多线…

    2026年5月10日
    000
  • 后缀php怎么打开_php文件打开方式与运行环境搭建指南

    要打开PHP文件需根据用途选择方式:查看代码可用文本编辑器或IDE,运行则需服务器环境。推荐新手使用XAMPP、WAMP等集成环境,将文件放入htdocs目录后访问localhost;开发者可利用PHP内置服务器,命令行执行php -S localhost:8000运行;高级用户可手动配置Apach…

    2026年5月10日
    000
  • C# 怎么使用 Serilog 或 NLog 记录日志_C# 日志记录框架使用指南

    Serilog和NLog是.NET中常用日志框架,Serilog支持结构化日志,配置简洁,适合集成Seq、Elasticsearch;NLog配置灵活,支持复杂规则,适用于企业级应用。两者均通过NuGet安装,配合配置文件或代码初始化,并通过ILogger接口写入日志,可根据项目需求选择其一。 在 …

    2026年5月10日
    000
  • Golang 文件IO操作与性能优化实践

    合理使用Go标准库并优化IO策略可显著提升文件处理性能。1. 使用bufio减少系统调用,适合小块读写;2. 大文件用流式读取避免OOM,小文件可一次性加载;3. 并发分片读取大文件并配合预读提升吞吐;4. 结合系统调优如O_DIRECT、关闭atime等防止IO瓶颈。 Go语言在文件IO操作上提供…

    2026年5月10日
    000
  • PHP动态网页数据库备份恢复_PHP动态网页MySQL数据库备份教程

    答案:PHP动态网页的MySQL数据库备份与恢复需通过定期导出SQL文件并安全存储来保障数据安全,核心方法包括使用mysqldump命令行工具实现高效灵活的自动化备份,利用phpMyAdmin图形化工具进行手动导出导入以降低操作门槛,以及通过PHP脚本调用系统命令将备份过程集成到应用中;恢复时可采用…

    2026年5月10日
    000
  • Go语言中sync.WaitGroup的深度解析与实践

    sync.WaitGroup是Go语言中用于并发编程的重要同步原语,它允许主协程等待一组子协程执行完毕。本文将深入探讨WaitGroup的工作原理、典型使用模式及其与sync.Mutex等其他同步机制的区别,并通过实际代码示例,帮助读者掌握其在并发控制中的应用,避免常见的误区,确保并发程序的正确性和…

    2026年5月10日
    000
  • C#怎么进行UDP通信 C# UdpClient实现UDP协议编程

    使用UdpClient类可简化C#中的UDP通信。1. 发送数据:创建UdpClient实例,调用Send()方法指定目标IP和端口,如向127.0.0.1:8888发送”Hello UDP!”;2. 接收数据:绑定端口(如8888),使用Receive()阻塞等待数据,通过…

    2026年5月10日
    100
  • php登录怎么实现_php用户登录系统完整实现

    <blockquote>PHP用户登录系统的核心是安全验证与会话管理。首先创建POST提交的登录表单,避免敏感信息暴露;后端通过session_start()启动会话,使用trim()和htmlspecialchars()清理输入,防止XSS攻击;利用PDO预处理语句查询数据库,防止SQ…

    用户投稿 2026年5月10日
    000
  • Linux用scp命令上传HTML文件到远程服务器

    使用scp命令可安全上传HTML文件至远程服务器:1、上传单个文件需指定源路径与目标地址;2、批量上传可用*.html通配符;3、递归上传目录需加-r参数;4、非默认端口需用-P指定端口号,依次执行并输入密码即可完成传输。 如果您需要将本地的HTML文件上传到远程服务器,并且拥有SSH访问权限,可以…

    2026年5月10日
    000
  • C#如何处理异常?C# try-catch-finally最佳实践与常见错误规避

    正确使用 try-catch-finally 应捕获具体异常、用 finally 或 using 释放资源、避免空 catch 和裸抛异常,确保异常日志记录并保留堆栈跟踪,提升代码健壮性与可维护性。 在C#中,异常处理是保障程序稳定运行的重要机制。正确使用 try-catch-finally 结构不…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信