mysql主从复制概述和配置

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【10月更文挑战第22天】MySQL 主从复制是一种将主服务器的数据复制到一个或多个从服务器的技术,实现读写分离,提高系统性能和可用性。主服务器记录变更日志,从服务器通过 I/O 和 SQL 线程读取并应用这些变更。适用于读写分离、数据备份和恢复、数据分析等场景。配置步骤包括修改配置文件、创建复制用户、配置从服务器连接主服务器并启动复制进程。
  1. 概述
  • 概念
  • MySQL 主从复制是一种数据库架构技术,用于将一个 MySQL 数据库服务器(主服务器)的数据复制到一个或多个其他 MySQL 数据库服务器(从服务器)。主服务器处理所有的写入(INSERT、UPDATE、DELETE)操作,这些操作产生的变更会通过复制机制传递到从服务器,从服务器主要用于读取操作,从而实现读写分离,提高数据库系统的整体性能和可用性。
  • 工作原理
  • 二进制日志(Binlog):主服务器将所有更改数据的 SQL 语句(如 INSERT、UPDATE、DELETE)记录到二进制日志中。这个日志是复制的基础,它包含了数据库变更的事件序列。例如,当主服务器上执行了一个 INSERT 语句插入一条新记录时,这个操作会被记录在二进制日志中。
  • 从服务器 I/O 线程:从服务器有一个 I/O 线程,它会连接到主服务器,请求获取主服务器二进制日志中的事件。然后将这些事件读取并存储到从服务器本地的中继日志(Relay Log)中。
  • 从服务器 SQL 线程:从服务器的 SQL 线程会读取中继日志中的事件,并将这些事件对应的 SQL 语句在从服务器上执行,从而使从服务器的数据与主服务器保持同步。例如,如果主服务器的二进制日志中有一个 UPDATE 语句,从服务器的 SQL 线程会从中继日志中读取这个 UPDATE 语句并在从服务器上执行,更新相应的数据。
  • 应用场景
  • 读写分离:在高并发的 Web 应用中,读操作通常远远多于写操作。通过主从复制,可以将读请求分配到从服务器上,减轻主服务器的负载,提高系统的整体性能。例如,一个电商网站,商品详情页的浏览(读操作)可以由从服务器处理,而用户下单(写操作)则由主服务器处理。
  • 数据备份和恢复:从服务器可以作为主服务器数据的备份。如果主服务器出现故障,在一定条件下,可以将从服务器提升为新的主服务器,快速恢复业务。同时,备份从服务器的数据也更加方便,不会影响主服务器的正常运行。
  • 数据分析和报表:可以在从服务器上进行数据分析和报表生成等操作,这些操作通常是复杂的只读操作,不会对主服务器的实时业务产生影响。例如,企业可以在从服务器上运行复杂的统计查询来生成销售报表。
  1. 配置步骤
  • 准备工作
  • 确保有至少两台 MySQL 服务器,分别作为主服务器和从服务器。它们需要能够相互通信,通常在网络配置上要允许从服务器访问主服务器的 MySQL 服务端口(默认是 3306)。
  • 安装好 MySQL 数据库软件,并启动 MySQL 服务。在配置主从复制之前,最好对两台服务器的 MySQL 进行基本的配置,如设置字符集、存储引擎等,确保它们能够正常运行。
  • 主服务器配置
  • 修改配置文件(my.cnf 或 my.ini):在主服务器上,打开 MySQL 的配置文件,找到并修改以下配置选项。
  • server - id:为每个服务器设置一个唯一的标识号,主服务器的server - id应该是一个较小的整数,例如1。这个选项用于在复制架构中区分不同的服务器。
  • log - bin:启用二进制日志,指定二进制日志文件的路径和名称前缀。例如,log - bin = /var/log/mysql/mysql - bin。这使得主服务器能够记录数据变更的事件。
  • 配置完成后,重启主服务器的 MySQL 服务,使配置生效。
  • 创建复制用户:在主服务器的 MySQL 客户端中,创建一个用于从服务器连接并进行复制操作的用户。例如,使用以下 SQL 语句:


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


这里创建了一个名为repl_user,密码为password的用户,并且授予该用户REPLICATION SLAVE权限,允许它从任何主机(%表示所有主机,在实际生产环境中应该指定从服务器的 IP 地址)连接到主服务器进行复制操作。最后,刷新权限使设置生效。


  • 获取主服务器状态信息:在主服务器的 MySQL 客户端中,执行以下 SQL 语句来获取主服务器的状态信息:


SHOW MASTER STATUS;


这个命令会显示主服务器二进制日志文件的名称(例如mysql - bin.000001)和当前日志文件中的位置(Position),从服务器在连接时需要这些信息来确定从哪里开始复制。


  • 从服务器配置
  • 修改配置文件(my.cnf 或 my.ini):在从服务器上,打开 MySQL 的配置文件,设置server - id为一个不同于主服务器的整数,例如2。这个标识号用于区分从服务器与主服务器以及其他可能存在的从服务器。
  • 配置从服务器连接主服务器:在从服务器的 MySQL 客户端中,执行以下 SQL 语句来配置从服务器连接主服务器:


CHANGE MASTER TO
       MASTER_HOST = '主服务器IP地址',
       MASTER_USER = 'repl_user',
       MASTER_PASSWORD = 'password',
       MASTER_LOG_FILE = '主服务器二进制日志文件名',
       MASTER_LOG_POS = 主服务器二进制日志位置;


需要将主服务器IP地址repl_userpassword主服务器二进制日志文件名主服务器二进制日志位置替换为实际的值。这些值是从主服务器获取的相关信息。


  • 启动从服务器复制进程:在从服务器的 MySQL 客户端中,执行以下 SQL 语句来启动复制进程:


START SLAVE;


  • 检查从服务器状态:执行以下 SQL 语句来检查从服务器的复制状态:


SHOW SLAVE STATUS\G;


这个命令会显示从服务器复制的详细状态信息。重点关注Slave_IO_RunningSlave_SQL_Running这两个字段,它们的值应该都为Yes,表示从服务器的 I/O 线程和 SQL 线程都在正常运行,主从复制正在顺利进行。如果出现问题,可以查看Last_Error字段来获取错误信息,以便进行故障排除。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
监控 关系型数据库 MySQL
深入了解MySQL主从复制:构建高效稳定的数据同步架构
深入了解MySQL主从复制:构建高效稳定的数据同步架构
130 1
|
2月前
|
存储 关系型数据库 MySQL
MySQL主从复制原理和使用
本文介绍了MySQL主从复制的基本概念、原理及其实现方法,详细讲解了一主两从的架构设计,以及三种常见的复制模式(全同步、异步、半同步)的特点与适用场景。此外,文章还提供了Spring Boot环境下配置主从复制的具体代码示例,包括数据源配置、上下文切换、路由实现及切面编程等内容,帮助读者理解如何在实际项目中实现数据库的读写分离。
MySQL主从复制原理和使用
|
1月前
|
存储 SQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Mysql And Redis基础与进阶操作系列(1)之[MySQL的下载、安装、配置详解步骤及报错对应解决方法]
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
98 2
|
2月前
|
存储 关系型数据库 MySQL
mysql 引擎概述
MySQL存储引擎是处理不同类型表操作的组件,InnoDB是最常用的默认引擎,支持事务、行级锁定和外键。MySQL采用插件式存储引擎架构,支持多种引擎,如MyISAM、Memory、CSV等,每种引擎适用于不同的应用场景。通过`SHOW ENGINES`命令可查看当前MySQL实例支持的存储引擎及其状态。选择合适的存储引擎需根据具体业务需求和引擎特性来决定。
|
2月前
|
SQL 关系型数据库 MySQL
Mysql中搭建主从复制原理和配置
主从复制在数据库管理中广泛应用,主要优点包括提高性能、实现高可用性、数据备份及灾难恢复。通过读写分离、从服务器接管、实时备份和地理分布等机制,有效增强系统的稳定性和数据安全性。主从复制涉及I/O线程和SQL线程,前者负责日志传输,后者负责日志应用,确保数据同步。配置过程中需开启二进制日志、设置唯一服务器ID,并创建复制用户,通过CHANGE MASTER TO命令配置从服务器连接主服务器,实现数据同步。实验部分展示了如何在两台CentOS 7服务器上配置MySQL 5.7主从复制,包括关闭防火墙、配置静态IP、设置域名解析、配置主从服务器、启动复制及验证同步效果。
Mysql中搭建主从复制原理和配置
|
2月前
|
关系型数据库 MySQL Java
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
这篇文章是关于如何使用Django框架配置MySQL数据库,创建模型实例,并自动或手动创建数据库表,以及对这些表进行操作的详细教程。
78 0
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
|
3月前
|
关系型数据库 MySQL Go
go抽取mysql配置到yaml配置文件
go抽取mysql配置到yaml配置文件
|
2月前
|
数据可视化 关系型数据库 MySQL
【IDEA】配置mysql环境并创建mysql数据库
【IDEA】配置mysql环境并创建mysql数据库
160 0
|
6天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。