MySQL主从复制原理及实现教程

news2025/1/23 3:54:43

MySQL主从复制是一种数据复制技术,通过建立主服务器(Master)与从服务器(Slave)之间的数据同步,实现数据的备份、负载均衡和高可用性。

主从复制原理

MySQL binlog(binary log 即二进制日志文件) 主要记录了 MySQL 数据库中数据的所有变化(数据库执行的所有 DDL 和 DML 语句)。因此,我们根据主库的 MySQL binlog 日志就能够将主库的数据同步到从库中。

日志机制

  • 主服务器记录所有更改数据的操作到二进制日志(Binary Log,简称为binlog)。
  • 从服务器通过读取主服务器的binlog来跟进数据变化,从而保持与主服务器的数据一致性。

复制过程

  • 主服务器(Master)处理所有的写操作,并将这些操作记录到binlog中。
  • 从服务器定期连接主服务器,获取binlog并进行解析,将其中的更改应用到本地数据库,以此实现数据同步。

工作模式

  • 异步复制:从服务器在确认更新后,主服务器并不会等到从服务器会话响应后再执行其他操作。可能导致数据延迟。
  • 半同步复制:主服务器在发送更新后,会等待至少一个从服务器确认已接收到该更新。
  • 全同步复制:主服务器在每次操作后,必须等待所有从服务器确认更新,这可能会影响性能。

实现教程

这里采用一主一从配置:

需要准备两台服务器,分别安装好MySQL

如果是一台服务器,则可以安装两个端口不一样的MySQL

配置主节点

  1. 编辑配置文件(my.cnf 或 my.ini):

    [mysqld] 
    server-id = 1 # 唯一的server-id 
    log_bin = mysql-bin # 启用二进制日志
  2. 重启主服务器

    sudo service mysql restart
  3. 创建复制用户
    登录到MySQL并执行:

    CREATE USER 'root'@'%' IDENTIFIED BY '123456'; 
    GRANT REPLICATION SLAVE ON *.* TO 'root'@'%'; 
    FLUSH PRIVILEGES;
  4. 锁定表并获取当前binlog文件和位置

    FLUSH TABLES WITH READ LOCK;  
    SHOW MASTER STATUS;

配置从节点

  1. 编辑配置文件

    [mysqld] 
    server-id = 2 # 唯一的server-id
  2. 重启从服务器

    sudo service mysql restart
  3. 配置从服务器连接主服务器
    登录到从服务器的MySQL并执行:

    CHANGE MASTER TO MASTER_HOST='主服务器的IP地址', 
    MASTER_USER='root', # 刚刚配置的主服务器的用户名
    MASTER_PASSWORD='123456', # 刚刚配置的主服务器的密码
    MASTER_log_file='mysql-bin.000001', # 主服务器SHOW MASTER STATUS获取的File MASTER_log_pos=123; # 主服务器SHOW MASTER STATUS获取的Position
  4. 启动从服务器复制

    START SLAVE;
  5. 检查复制状态

    SHOW SLAVE STATUS\G;

    确保 Slave_IO_Running 和 Slave_SQL_Running 都是 Yes

解锁主服务器的表

再回到主服务器执行:

UNLOCK TABLES;

注意事项

  • 确保主从节点的时钟同步。
  • 在主节点上修改数据后,不要进行DROP操作或者直接删除binlog文件,可能导致从节点无法同步。
  • 不能对从节点进行删除数据的操作,如果在从节点上手动删除数据,可能导致主从数据不一致,破坏复制的一致性。在一些特定情况下,例如为了数据清理或符合业务需求,可能需要直接在从节点上操作,但要确保了解这些操作的后果,并能在必要时手动同步数据。
  • 建议将从节点设置为只读模式,防止在从节点上进行数据修改。可以通过以下配置项设置从节点为只读:
  • SET GLOBAL read_only = ON;
  • 进行备份时,应避免对主数据库的频繁访问。

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

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

相关文章

Python 如何创建和操作矩阵?

在Python中,矩阵是二维数组的一种常见表示方式,特别是在数学和科学计算领域。矩阵用于表示和操作多维数据,包括数据分析、图像处理、机器学习、以及物理模拟等诸多领域。Python的NumPy库是处理矩阵的主要工具之一。NumPy提供了高效的多维数组…

Deformable Detr

参考: https://search.bilibili.com/all?vt68804228&keywordco-detr&from_sourcewebtop_search&spm_id_from333.1007&search_source5 详解可以看李宏毅的transformer视频。

SAP MM维护采购信息记录只到采购组织层级时候,税码输入报错 MESSAGE 06388

原因:税确认应该是在工厂层级 解决:对06388 消息号进行更改类型改成W

Java-文件操作和IO

文件介绍 文件本身有多重含义,狭义的文件,特指硬盘上的文件(以及保存文件的目录),广义的文件:计算机上的很多硬件设备,软件资源,在操作系统中,都会被视为是"文件" 文件除了有数据内容之外,还有一部分信息,例如文件名,文件类型,文件大小,这些信息可以称作文件的元信…

Redis-管道

面试题 如何优化频繁命令往返造成的性能瓶颈 Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务。一个请求会遵循以下步骤: 1 客户端向服务端发送命令分四步(发送命令-命令排队一命令执行-返回结果),并监听Socket返回,通常以阻塞模式等待服…

看完这八本AI产品经理书籍,offer收的手软,收藏我这一篇就够了

对于想要深入了解人工智能领域并成为一名优秀的人工智能产品经理的专业人士来说,选择合适的书籍至关重要。下面是我为您精心挑选的八本关于AI产品经理领域的书籍,它们涵盖了从基础知识到高级实践的各个方面,旨在帮助读者构建全面的知识体系。…

情人节变情人劫?三好夫人:为何好男人怕过节

真正的爱,是两颗心灵的相互靠近,是理解、尊重与支持的结晶。———三好夫人 七夕节来源 2024年8月10是中国传统的情人节--七夕。七夕又称七巧节、七姐节、女儿节。妇女们在这一天相约,穿针乞巧,投针验巧,祈求得到智慧…

三十种未授权访问漏洞复现 合集( 一 )

未授权访问漏洞介绍 未授权访问可以理解为需要安全配置或权限认证的地址、授权页面存在缺陷,导致其他用户可以直接访问,从而引发重要权限可被操作、数据库、网站目录等敏感信息泄露。---->目录遍历 目前主要存在未授权访问漏洞的有:NFS服务&a…

全网最清晰Endnote教程笔记,轻松搞定文献管理以及文献引用

提示:从安装到使用,全网最清晰EndNote教程,轻松搞定文献管理!_哔哩哔哩_bilibili 目录 前言 1 导入文献 1.1 文献数据库建立 1.2 正式导入文献 1.3 Endnote导入PDF文献 2 管理文献 3. 引用文献 3.1 Endnote预览参考文献样…

搭建 Rancher 服务,配置k8s集群

1. 前提条件 前提条件: 安装docker,要求版本各节点版本一致。网上还有额外的要求:关闭swap、禁用selinux等等。 2. 搭建 Rancher 服务 直接通过docker命令实现即可,很方便。 docker run -d \--name rancher \--restart unles…

数学建模-数据预处理(数据清洗、标准化)

在数学建模的比赛中,数据分析类的题目中往往我们要面对大量的数据,在给出的数据中,如果数据缺失会影响到判断和后序的操作 这里我们给出一个数据预处理的办法:数据清洗(Data Clearning):涉及到…

良心推荐——揭秘10款文件加密软件!(小编真心推荐!好用!)

文件加密不仅能够有效防止敏感数据被非法获取或篡改,还能在数据丢失或被盗时降低损失。 因此,选择一款高效、可靠的文件加密软件成为了企业保障信息安全不可或缺的一环。 今天,小编就为大家揭秘10款良心推荐的文件加密软件,其中首…

BurpSuite教程——渗透测试第一关:BP工具使用

想要学好网络渗透,了解并熟练使用渗透工具是重要的一关。 Burp Suite 是一款广泛使用的网络安全工具,主要用于测试Web应用程序的安全性。它提供了一系列的功能,帮助安全专家和渗透测试人员发现和利用Web应用程序中的安全漏洞。 目录 一、前…

JetBrains GoLand单元测试不支持单个单元测试case执行

譬如函数代码 func AddInt(a, b int32) int32 {return a b } 单元测试代码: func TestAddInt(t *testing.T) {type args struct {a int32b int32}tests : []struct {name stringargs argswant int32}{{name: "add",args: args{a: 1, b: 2},want: 3},{n…

安卓自定义控件

文章目录 引入布局创建自定义控件 引入布局 首先创建一个项目&#xff0c;创建一个空的活动。然后右键单击res/layout创建一个Layout Resource File文件&#xff0c;取名title.xml。 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmln…

【Android Studio】彻底卸载

文章目录 卸载程序控制面板卸载安全软件卸载 删除文件重启计算机 我们在Android开发时涉及重装时&#xff0c;如果卸载不干净&#xff0c;再次安装是不会正常运行项目的&#xff0c;接下来就让我教你如何删除干净吧。 卸载程序 控制面板卸载 control控制面板一>程序一>…

算法通关:016:设计循环双端队列

文章目录 题目思路代码运行结果问题为什么能直接调用方法名 题目 leetcode641 设计循环双端队列 思路 代码 import java.util.Deque; import java.util.LinkedList;/*** Author: ggdpzhk* CreateTime: 2024-08-03* 641 双端队列&#xff1a;利用双向链表和动态数组实现*/ pu…

百款HTML5小游戏源码搭建的网站,轻松为你的小程序或网站增加流量!

百款HTML5小游戏源码搭建的网站&#xff0c;轻松为你的小程序或网站增加流量&#xff01; 访问链接&#xff1a;http://43.139.69.156/game/80h5/index.html 需要源码可以看主页介绍 &#x1f680;&#x1f31f; 引爆你的创意&#xff01;100款HTML5小游戏源码大公开&#xff…

kettle从入门到精通 第八十三课 ETL之kettle kettle调用python且接收返回值

场景&#xff1a;kettle调用python执行脚本&#xff0c;处理之后&#xff0c;再把结果数据流发给下一个步骤。 看到有个qq群里有个小伙伴求助要实现kettle调用python脚本&#xff0c;然后接收python脚本执行的结果&#xff0c;最后将结果传递到下一个步骤。之前的课程里面介绍的…

bugku-web-xxx二手交易市场

打开题目&#xff0c;点击进入链接&#xff0c;是一个二手交易市场平台 先登录看看 评论了两下&#xff0c;发现<>被注释 对注释字符进行了过滤&#xff0c;无法闭合&#xff0c;sql注入点不存在 看看头像上传&#xff0c;上传文件&#xff0c;抓包 看到后面好长一串…