mysql的主从同步

news/2024/10/20 1:26:45/

MySQL的主从同步是一种数据复制技术,它允许将一个MySQL数据库服务器上的数据变化自动复制到一个或多个MySQL数据库服务器上。主从同步广泛用于高可用性、负载均衡、读写分离和数据备份。下面详细介绍MySQL主从同步的原理、配置步骤、常见问题及解决方法。

一、基本原理
MySQL主从同步的基本原理包括以下几个步骤:
主服务器记录二进制日志:主服务器上的数据变化(如INSERT、UPDATE、DELETE操作)被记录到二进制日志(binlog)中。
从服务器读取二进制日志:从服务器通过I/O线程从主服务器读取二进制日志并写入本地的中继日志(relay log)。
从服务器应用中继日志:从服务器的SQL线程读取中继日志并执行其中的SQL语句,使从服务器的数据与主服务器的数据保持同步。
二、配置步骤

  1. 在主服务器上进行配置
    修改配置文件(通常是 my.cnf 或 my.ini):
[mysqld]
log-bin=mysql-bin       # 启用二进制日志
server-id=1             # 主服务器ID,需唯一

创建用于复制的用户:

CREATE USER 'replica'@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'replica'@'%';
FLUSH PRIVILEGES;

查看二进制日志位置:

SHOW MASTER STATUS;

记录输出中的 File 和 Position 值。

  1. 在从服务器上进行配置
    修改配置文件(通常是 my.cnf 或 my.ini):
[mysqld]
server-id=2             # 从服务器ID,需唯一且不同于主服务器

配置从服务器连接主服务器:

CHANGE MASTER TOMASTER_HOST='master_host_ip',MASTER_USER='replica',MASTER_PASSWORD='password',MASTER_LOG_FILE='mysql-bin.000001',   # 在上一步中记录的File值MASTER_LOG_POS=12345;                 # 在上一步中记录的Position值

启动复制:

START SLAVE;
  1. 检查主从同步状态
    在从服务器上运行以下命令检查同步状态:
SHOW SLAVE STATUS\G

查看输出,确保 Slave_IO_Running 和 Slave_SQL_Running 都为 Yes。另外,检查 Last_IO_Error 和 Last_SQL_Error 确保没有错误。

三、常见问题与解决
从服务器延迟:如果从服务器处理日志的速度赶不上主服务器,可以考虑提升从服务器的硬件配置或优化数据库查询。

网络问题:网络不稳定可能导致同步中断,确保主从服务器之间的网络连接稳定。

主从不一致:如果主从数据不一致,可以使用 pt-table-checksum 和 pt-table-sync 工具进行数据校验和同步。

二进制日志溢出:主服务器的二进制日志会占用磁盘空间,需要定期清理旧的二进制日志。可以在主服务器的配置文件中设置 expire_logs_days 参数自动清理过期日志。

四、高级配置
多线程复制:从MySQL 5.7开始,支持多线程复制,通过设置 slave-parallel-workers 参数可以启用多线程,提高从服务器的同步效率。

[mysqld]
slave-parallel-workers=4  # 设置从服务器使用4个SQL线程并行处理

半同步复制:半同步复制确保至少一个从服务器收到主服务器的二进制日志后,主服务器才会提交事务,提高数据的可靠性。

[mysqld]
rpl_semi_sync_master_enabled=1  # 启用主服务器上的半同步复制
rpl_semi_sync_slave_enabled=1   # 启用从服务器上的半同步复制

延迟复制:可以通过设置从服务器的 MASTER_DELAY 参数实现延迟复制,用于防止主服务器上的误操作立即同步到从服务器。

CHANGE MASTER TO MASTER_DELAY = 3600;  # 设置延迟时间为3600秒(1小时)

五、主从同步的优缺点
优点
高可用性:通过主从同步,可以实现故障转移,提高数据库的可用性。
负载均衡:读写分离,将读操作分散到多个从服务器上,提高系统的整体性能。
数据备份:从服务器可以作为数据备份的一部分,防止数据丢失。
缺点
数据一致性问题:在某些情况下,主从数据可能会不一致,需要定期检查和修复。
网络开销:主从同步依赖网络传输,网络状况不佳可能影响同步效率。
配置复杂:主从同步需要对主从服务器进行配置和管理,增加了系统复杂性。
六、应用场景
高可用架构:在高可用系统中,通过主从同步实现故障转移,保证系统的稳定性。
读写分离:在高并发的应用中,通过主从同步实现读写分离,提高系统的并发处理能力。
数据备份与恢复:通过从服务器实现实时数据备份,防止数据丢失,并在需要时快速恢复数据。
MySQL主从同步是一种重要的数据复制技术,通过合理的配置和管理,可以实现高可用性、负载均衡和数据备份等目标。在实际应用中,需要根据具体需求和环境进行优化和调整,以达到最佳效果。


http://www.ppmy.cn/news/1469656.html

相关文章

Mac M3 Pro 安装 Zookeeper-3.4.6

1、下载安装包 官方下载地址:https://archive.apache.org/dist/zookeeper/ 网盘下载地址:https://pan.baidu.com/s/1j6iy5bZkrY-GKGItenRB2w?pwdirrx 提取码: irrx 2、解压并添加环境变量 # 将安装包移动到目标目录 mv ~/Download/zookeeper-3.4.6.…

分布式物联网平台特点

随着物联网(IoT)技术的飞速发展,我们正步入一个万物互联的新时代。在这个时代,设备、数据和服务的无缝集成是实现智能化的关键。分布式物联网平台作为这一进程的核心,正在成为构建智能世界的基石。 一、分布式物联网平…

【git使用四】git分支理解与操作(详解)

目录 (1)理解git分支 主分支(主线) 功能分支 主线和分支关系 将分支合并到主分支 快速合并 非快速合并 git代码管理流程 (2)理解git提交对象 提交对象与commitID Git如何保存数据 示例讲解 &a…

Mongodb使用$<identifier>过滤更新数组元素

学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第65篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。如果您认为我的文章对您有帮助或者解决您的问题,欢迎在文章下面点个赞,或者关…

C++ 49 之 继承的访问权限

#include <iostream> #include <string> using namespace std;// 基类、父类 class Base2{ public://公共的int m_a;protected:// 受保护的int m_b;private:// 私有的int m_c; };// 公共继承 public class Son2 : public Base2{ public:void fun1(){m_a 100; …

kotlin 协程之初识挂起函数

什么是挂起函数 官方文档 在 Kotlin 协程:从基础概念到开发实践 文章中,提到 kotlin协程 是一个可挂起计算的实例,可以在一个线程中挂起并在另一个线程中恢复继续执行,这期间不会阻塞线程。 这种挂起和恢复的能力就是通过挂起函数来实现的。 在使用示例中,我们用到了 w…

课设--学生成绩管理系统(一)

欢迎来到 Papicatch的博客 文章目录 &#x1f349;技术核心 &#x1f349;引言 &#x1f348;标识 &#x1f348;背景 &#x1f348;项目概述 &#x1f348; 文档概述 &#x1f349;可行性分析的前提 &#x1f348;项目的要求 &#x1f348;项目的目标 &#x1f348;…

如何开发高效服务(C++ )

在 C 开发高效服务器时&#xff0c;常用的开发模式和设计模式能够帮助你构建高效、可扩展和可维护的服务器。以下是一些常见的模式和设计模式&#xff1a; 1. 并发和并行编程模型 1.1 Reactor 模式 Reactor 模式是一种事件驱动设计模式&#xff0c;广泛用于高性能服务器编程…