mysql主从复制怎么配置_mysql复制机制说明

MySQL主从复制通过binlog实现数据同步,主库记录变更日志,从库拉取并重放日志。配置需设置server-id、启用binlog和relay log,创建复制用户,执行CHANGE MASTER并启动SLAVE,最后检查Slave_IO_Running和Slave_SQL_Running状态为Yes即可正常同步。

mysql主从复制怎么配置_mysql复制机制说明

MySQL主从复制是一种常见的数据同步机制,用于将一个MySQL数据库(主库)的数据自动同步到一个或多个从库。这种架构常用于读写分离、数据备份和高可用性部署。

主从复制的基本原理

MySQL主从复制基于二进制日志(Binary Log)机制。主库记录所有对数据产生更改的操作(如INSERT、UPDATE、DELETE),从库通过I/O线程读取主库的二进制日志,并将日志内容写入本地的中继日志(Relay Log)。然后由SQL线程读取中继日志并重放这些操作,从而实现数据同步。

整个过程包括以下三个关键步骤:

记录日志:主库开启binlog,记录所有数据变更操作。拉取日志:从库启动I/O线程,连接主库并请求binlog更新。执行日志:从库的SQL线程解析并执行中继日志中的语句。

配置主从复制的步骤

假设主库IP为192.168.1.100,从库IP为192.168.1.101,使用MySQL 5.7或以上版本。

1. 配置主库(Master)

编辑主库的配置文件 my.cnf(通常位于 /etc/my.cnf 或 /etc/mysql/my.cnf):

[mysqld]server-id = 1log-bin = mysql-binbinlog-format = ROWexpire_logs_days = 7

说明:

server-id:每台MySQL服务器必须有唯一ID,主库设为1。log-bin:启用二进制日志,命名为mysql-bin。binlog-format:推荐使用ROW格式,更安全且便于数据恢复

重启MySQL服务后,登录MySQL创建用于复制的账号:

mysql> CREATE USER 'repl'@'192.168.1.%' IDENTIFIED BY 'slavepass';mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.1.%';mysql> FLUSH PRIVILEGES;

查看主库当前binlog状态:

mysql> SHOW MASTER STATUS;

记下返回结果中的 FilePosition,后续从库配置需要使用。

2. 配置从库(Slave)

吐槽大师 吐槽大师

吐槽大师(Roast Master) – 终极 AI 吐槽生成器,适用于 Instagram,Facebook,Twitter,Threads 和 Linkedin

吐槽大师 94 查看详情 吐槽大师

编辑从库的 my.cnf 文件:

[mysqld]server-id = 2relay-log = mysql-relay-binlog-slave-updates = 1read-only = 1

说明:

server-id:必须与主库不同,设为2。relay-log:指定中继日志名称。read-only:防止从库被误写入数据。

重启从库MySQL服务,然后在MySQL中执行如下命令:

mysql> CHANGE MASTER TO  MASTER_HOST='192.168.1.100',  MASTER_USER='repl',  MASTER_PASSWORD='slavepass',  MASTER_LOG_FILE='mysql-bin.000001',  -- 替换为SHOW MASTER STATUS中的File值  MASTER_LOG_POS= 154;                  -- 替换为Position值

mysql> START SLAVE;

3. 检查复制状态

运行以下命令查看从库是否正常同步:

mysql> SHOW SLAVE STATUSG

重点关注两个字段:

Slave_IO_Running: YesSlave_SQL_Running: Yes

如果都是Yes,表示复制正常。如果有错误,可查看 Last_Error 字段进行排查。

常见问题与注意事项

主从复制虽然稳定,但配置不当容易出错。以下是几个常见问题及建议:

确保主从时间同步,使用NTP服务避免时间偏差影响日志应用。主从服务器的MySQL版本尽量保持一致或兼容。避免在从库执行写操作,否则会导致数据不一致。网络不稳定可能导致复制延迟,可通过监控Seconds_Behind_Master判断。建议定期备份从库数据,提高容灾能力。

基本上就这些。只要主库开启了binlog,从库正确连接并开始复制,数据就能持续同步。复制机制本身是异步的,性能开销小,适合大多数业务场景。

以上就是mysql主从复制怎么配置_mysql复制机制说明的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 23:34:19
下一篇 2025年12月2日 23:34:40

相关推荐

  • 网络进化!

    Web 应用程序从静态网站到动态网页的演变是由对更具交互性、用户友好性和功能丰富的 Web 体验的需求推动的。以下是这种范式转变的概述: 1. 静态网站(1990 年代) 定义:静态网站由用 HTML 编写的固定内容组成。每个页面都是预先构建并存储在服务器上,并且向每个用户传递相同的内容。技术:HT…

    2025年12月24日
    000
  • 为什么多年的经验让我选择全栈而不是平均栈

    在全栈和平均栈开发方面工作了 6 年多,我可以告诉您,虽然这两种方法都是流行且有效的方法,但它们满足不同的需求,并且有自己的优点和缺点。这两个堆栈都可以帮助您创建 Web 应用程序,但它们的实现方式却截然不同。如果您在两者之间难以选择,我希望我在两者之间的经验能给您一些有用的见解。 在这篇文章中,我…

    2025年12月24日
    000
  • 揭示绝对定位的缺点并提出解决方案:常见问题的规避策略

    绝对定位的弊端揭秘:如何避免常见问题? 绝对定位是网页设计中常用的一种布局方式,它可以让元素精确地定位在页面上的指定位置。然而,尽管绝对定位在某些情况下非常有用,但它也存在一些弊端。本文将揭示绝对定位的弊端,并提供一些方法来避免常见问题。 首先,绝对定位的一个弊端是元素定位可能受到浏览器窗口大小的影…

    2025年12月24日
    000
  • 常见问题和解决方法:绝对定位运动指令的疑问与解答

    绝对定位运动指令的常见问题及解决方法 摘要:随着技术的不断进步,绝对定位运动在现代机械设备中得到了广泛应用。然而,在使用绝对定位运动指令的过程中,常常会遇到各种问题。本文将重点讨论常见的绝对定位运动指令问题,并提供相应的解决方法和具体的代码示例。 一、绝对定位运动指令简介绝对定位运动指令是指根据目标…

    2025年12月24日
    000
  • 揭秘绝对定位故障:常见问题和解决方法曝光

    绝对定位故障大揭秘:常见问题及解决方案 引言: 绝对定位(Absolute positioning)是CSS中常用的一种定位方式,它允许开发者将元素精确地放置在一个给定的位置上。然而,由于其特殊的性质和较为复杂的用法,绝对定位经常会出现各种问题。本文将揭示绝对定位的常见故障,并提供相应的解决方案,同…

    2025年12月24日
    000
  • 详解Css Flex 弹性布局中的常见问题及解决方案

    详解CSS Flex弹性布局中的常见问题及解决方案 引言:CSS Flex弹性布局是一种现代的布局方式,其具有优雅简洁的语法和强大的灵活性,广泛应用于构建响应式的web页面。然而,在实际应用中,经常会遇到一些常见的问题,如元素排列不如预期、尺寸不一致等。本文将详细介绍这些问题,并提供相应的解决方案,…

    2025年12月24日
    200
  • CSS如何实现任意角度的扇形(代码示例)

    本篇文章给大家带来的内容是关于CSS如何实现任意角度的扇形(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 扇形制作原理,底部一个纯色原形,里面2个相同颜色的半圆,可以是白色,内部半圆按一定角度变化,就可以产生出扇形效果 扇形绘制 .shanxing{ position:…

    2025年12月24日
    000
  • CSS的选择器有哪些常见问题

    这次给大家带来css的选择器有哪些常见问题,处理css的选择器常见问题的注意事项有哪些,下面就是实战案例,一起来看一下。 选择器常见的有哪几种?1.标签选择器p{ }/选择标签名为p的元素/2.类选择器.box{ }/选择class名为box的元素/3.ID选择器#header{ }/选择id名为h…

    好文分享 2025年12月24日
    000
  • HTML里的常见问题一

    这次给大家带来在html里有哪些经常出现的问题?有序列表、无序列表、自定义列表如何使用?写个简单的例子。三者在语义上有什么区别?使用场景是什么? 能否嵌套? 有序列表是以数字进行标记的列表项目: CoffeeMilk 效果如下: CoffeeMilk 无序列表是以原点标记的列表项目: CoffeeM…

    好文分享 2025年12月24日
    000
  • HTML里的常见问题二

    如何去查css熟悉的兼容性?比如inline-block哪些浏览器支持?a 标签的href, title, target 是什么? title 和 alt有什么区别?如何新窗口打开链接?display: none和visibility: hidden有什么作用?有什么区别? line-height有…

    好文分享 2025年12月24日
    000
  • Redis配置文件redis.conf详细配置说明

    本文列出了redis的配置文件redis.conf的各配置项的详细说明,简单易懂,有需要的盆友可以参考哦。 redis.conf 配置项说明如下 redis配置文件详解 # vi redis.confdaemonize yes #是否以后台进程运行pidfile /var/run/redis/red…

    好文分享 2025年12月24日
    000
  • CSS的Word中的列表详解

    在word中,列表也是使用频率非常高的元素。在css中,列表和列表项都是块级元素。也就是说,一个列表会形成一个块框,其中的每个列表项也会形成一个独立的块框。所以,盒模型中块框的所有属性,都适用于列表和列表项。 除此之外,列表还有 3 个特有的属性 list-style-type、list-style…

    2025年12月24日
    000
  • html5能否禁用搜索框自动填充_html5autocomplete关闭方法【教程】

    禁用HTML5搜索框自动填充有五种方法:一、设autocomplete=”off”;二、随机化name/id值;三、用无效autocomplete值如”nope”;四、JS动态设置autocomplete;五、设autocomplete=”…

    2025年12月23日
    000
  • html5怎么插入文档_HT5用object或iframe嵌入PDF/Word文档显示【插入】

    可在HTML5中用iframe或object标签嵌入PDF,需设宽高及可访问路径;Word文档需借OneDrive等第三方服务代理渲染;须处理跨域限制并提供下载降级方案。 如果您希望在HTML5页面中嵌入PDF或Word文档并直接显示,可以使用或标签实现。以下是几种可行的嵌入方法: 一、使用ifra…

    2025年12月23日
    200
  • html5如何制作侧边抽屉菜单_html5侧边栏滑入滑出效果实现【攻略】

    侧边抽屉菜单可通过五种方式实现:一、Checkbox Hack纯CSS控制;二、JS切换class;三、visibility+transform组合;四、CSS变量动态管理;五、IntersectionObserver滚动自动收起。 如果您希望在网页中实现侧边抽屉菜单,使用户点击按钮后侧边栏从屏幕边…

    2025年12月23日
    000
  • 如何操作html_操作HTML元素的常用方法【常用】

    必须掌握操作HTML元素的五种核心方法:一、通过ID精准获取并修改单个元素;二、通过类名批量操作多个元素;三、用querySelector系列灵活选择任意CSS匹配元素;四、动态创建并插入新元素;五、安全移除或替换现有元素。 如果您需要动态修改网页内容或响应用户交互,则必须掌握操作HTML元素的核心…

    2025年12月23日
    200
  • html5怎么交css_html5用link外链或style内嵌引入css样式生效【引入】

    CSS样式未生效时,应依次检查link外链路径与MIME类型、style内嵌位置与语法、行内style属性格式,并通过开发者工具的Elements、Styles和Computed面板验证加载与优先级。 如果您在HTML5文档中尝试引入CSS样式但页面未按预期渲染,则可能是由于CSS引入方式不正确或路…

    2025年12月23日
    000
  • html5怎么换颜色_HT5用JS改CSS color或background-color切换颜色【更换】

    可通过操作DOM元素的style属性动态修改文本或背景颜色,方法包括:一、直接修改内联样式;二、切换预定义CSS类;三、修改CSS自定义属性;四、用getComputedStyle读取并智能计算新颜色;五、通过setAttribute设置style字符串。 如果您希望在HTML5页面中通过JavaS…

    2025年12月23日
    000
  • html5拖放怎么操作_HT5用draggable属性或JS监听drag事件实现拖放【操作】

    HTML5拖放功能需五步实现:一、设draggable=”true”启用拖动;二、用dragstart设置dataTransfer数据与视觉反馈;三、目标容器监听dragover并preventDefault;四、监听drop事件获取数据并操作DOM;五、dataTransf…

    2025年12月23日
    000
  • html5怎么好卡_HTML5优化代码用懒加载减少重排提升渲染速度【优化】

    HTML5页面性能优化需五步:一、图片懒加载用Intersection Observer;二、移除隐藏DOM节点;三、动画改用transform/opacity;四、长列表启用虚拟滚动;五、JS任务拆分并延迟执行。 如果您的HTML5页面加载缓慢、滚动卡顿或交互响应迟滞,很可能是由于大量图片或模块在…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信