MySQL的延迟复制

MySQL的延迟复制

MySQL 中的延迟复制(Delayed Replication)是一种特殊的复制配置,它允许从服务器在应用主服务器上的更改之前等待一段时间。这种配置通常用于实现数据的"时间旅行"功能,即能够恢复到过去某个时间点的状态,或者用于实现某些特定的业务逻辑需求,比如数据分析、报告生成等场景。

延迟复制的工作原理

在标准的主从复制配置中,从服务器会立即应用主服务器上的更改。而在延迟复制配置中,从服务器会根据预先设定的时间间隔(秒数)来延迟应用这些更改。

  1. 主服务器:接收写操作,并将这些操作记录到二进制日志中。
  2. 从服务器:读取主服务器的二进制日志,并将这些操作记录到中继日志中。但与标准复制不同的是,从服务器会等待一定的时间之后再执行这些操作。

延迟复制的配置步骤

以下是在 MySQL 中配置延迟复制的基本步骤。假设我们有一个主服务器(Master)和一个从服务器(Slave)。

步骤 1: 准备主服务器
  1. 开启二进制日志:确保主服务器的二进制日志功能已开启。

    ini 复制代码
    [mysqld]
    log_bin = /path/to/mysql-bin.log
    binlog_format = ROW
    server-id = 1
  2. 创建复制用户:在主服务器上创建一个用于复制的用户。

    sql 复制代码
    CREATE USER 'repl'@'%' IDENTIFIED BY 'password';
    GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
    FLUSH PRIVILEGES;
  3. 获取二进制日志的位置:记录当前的二进制日志文件名和位置,稍后从服务器需要用到这些信息。

    sql 复制代码
    SHOW MASTER STATUS;
步骤 2: 准备从服务器
  1. 配置从服务器:确保从服务器的配置正确,并启用延迟复制。

    ini 复制代码
    [mysqld]
    server-id = 2
    relay-log = /path/to/mysql-relay-bin.log
  2. 初始化从服务器:从主服务器导出数据并导入到从服务器。

    sql 复制代码
    # 在主服务器上
    mysqldump --all-databases > all-databases.sql
    # 将 all-databases.sql 复制到从服务器
    # 在从服务器上
    mysql < all-databases.sql
  3. 配置复制:在从服务器上配置复制,并启用延迟复制。

    sql 复制代码
    CHANGE MASTER TO
    MASTER_HOST='master_host',
    MASTER_USER='repl',
    MASTER_PASSWORD='password',
    MASTER_LOG_FILE='mysql-bin.000001',
    MASTER_LOG_POS=1234,
    RELAY_LOG_FILE='mysql-relay-bin.000001',
    RELAY_LOG_POS=1234,
    MASTER_DELAY=3600;  # 延迟 1 小时

    其中 MASTER_LOG_FILEMASTER_LOG_POS 是之前从主服务器获取的信息,RELAY_LOG_FILERELAY_LOG_POS 是从服务器上中继日志的位置。

  4. 启动复制:启动从服务器上的复制进程。

    sql 复制代码
    START SLAVE;
步骤 3: 验证复制状态
  1. 查看复制状态:在从服务器上检查复制状态。

    sql 复制代码
    SHOW SLAVE STATUS\G

    如果复制正常工作,您应该能看到类似 Slave_IO_Running: YesSlave_SQL_Running: Yes 的输出。

  2. 检查延迟状态:确认延迟复制是否按预期工作。

    sql 复制代码
    SELECT *
    FROM performance_schema.replication_applier_status_current
    WHERE channel_name = 'group_replication_applier';

    查看 last_sql_delay 字段,确认其值是否为配置的延迟时间。

相关推荐
找藉口是失败者的习惯17 分钟前
从传统到未来:Android XML布局 与 Jetpack Compose的全面对比
android·xml
小技与小术1 小时前
数据库表设计范式
数据库·mysql
安迁岚1 小时前
【SQL Server】华中农业大学空间数据库实验报告 实验三 数据操作
运维·服务器·数据库·sql·mysql
安迁岚1 小时前
【SQL Server】华中农业大学空间数据库实验报告 实验九 触发器
数据库·sql·mysql·oracle·实验报告
Loganer1 小时前
MongoDB分片集群搭建
数据库·mongodb
LKID体1 小时前
Python操作neo4j库py2neo使用之创建和查询(二)
数据库·python·neo4j
打码人的日常分享1 小时前
商用密码应用安全性评估,密评整体方案,密评管理测评要求和指南,运维文档,软件项目安全设计相关文档合集(Word原件)
运维·安全·web安全·系统安全·规格说明书
Jinkey2 小时前
FlutterBasic - GetBuilder、Obx、GetX<Controller>、GetxController 有啥区别
android·flutter·ios
vmlogin虚拟多登浏览器2 小时前
虚拟浏览器可以应对哪些浏览器安全威胁?
服务器·网络·安全·跨境电商·防关联
刘大浪2 小时前
后端数据增删改查基于Springboot+mybatis mysql 时间根据当时时间自动填充,数据库连接查询不一致,mysql数据库连接不好用
数据库·spring boot·mybatis