news 2026/2/11 4:12:25

MySQL主从数据同步实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL主从数据同步实战

什么是数据同步?

想想这样一个场景:今天10点开放考试成绩查询的入口,那么在10点钟会有一大波流量高峰,一台服务器肯定扛不住了。而且这种情况几乎没有数据更新操作,都是数据查询。

类似这样的查询请求非常高的情况下,适合用数据库的主从复制,多台服务器分散数据库的压力。

简单说就是有多台服务器,都安装了MySQL数据库,其中一台服务器上的MySQL数据库被人为定义为主数据库,负责数据的增删改操作。

剩下的所有服务器,都被定义为从数据库。

主数据库所有执行过的脚本,会自动保存为binlog日志文件。从数据库自动向主数据库获取主数据库的binlog文件,并自动在从数据库执行binlog中的命令。从而达到主从数据库数据同步。

如何数据同步?

要完成主从数据同步,不需要额外工具,MySQL提供了主从数据同步的功能。主要分为两步:

第一步是主数据库创建用户,并赋权给从数据库。

第二步是从数据库定义对应主数据库的参数,也就是要能找到那台服务器是主数据库。

主数据库配置操作

#=====MASTER脚本(主库)=========

#slave 是用户名 后面 slave 是密码
#是允许访问的远程IP地址,这里要写从属服务器的IP
create user 'slave'@'192.168.10.51' IDENTIFIED by 'slave';

#为slave用户授予主从复制的权限
grant replication slave on *.* to 'slave'@'192.168.10.51';

#激活权限
flush PRIVILEGES;

注意:如果有多个从库,create user XXX,grant replication XXX,这两个语句写多份即可,IP需要是对应从库的IP。用户名和密码建议每个从库设置不一样的值,便于区分。例如:slave1、slave2...

查询主数据库状态

show master status;

file字段的值就是当前主数据库binlog文件的名称,随着数据库中数据的不断操作,binlog文件也会自动增加。

查看binlog文件的内容

show binlog events in 'binlog.000003';

Pos是binlog日志文件开始位置。

End_log_pos是binlog文件结束位置。

Log_name是binlog日志文件名称。

Event_type是数据库操作的类型。

Info是操作对应的脚本。

从数据库配置操作

首先要把数据库配置改下,避免与主库冲突。

找到数据库安装目录下面的my.ini文件

修改server-id属性的值。

修改完成后,重启MySQL服务。

#========SLAVE脚本(从库)==========

RESET SLAVE ALL;


CHANGE MASTER TO
MASTER_HOST='192.168.0.111'
,MASTER_PORT=3306
,MASTER_USER='slave'
,MASTER_PASSWORD='slave'
,MASTER_LOG_FILE='binlog.000003'
,MASTER_LOG_POS=210099380;

192.168.0.111地址为主库的IP地址,需要能够在从库的服务器上访问到这个IP。

下面的用户名和密码,对应主库创建的用户名和密码。

MASTER_LOG_FILE:主库binlog文件名称

MASTER_LOG_POS:主库的该位置后的操作,会自动往从库进行同步,值来自主库的show master status;查询结果的Position字段值。

开始主从复制

start slave;

查询从库状态

show slave status;

确保这两个字段值都是Yes,说明主从配置完成。

注意:如果有多个从库,把上面的操作分别在每个从库进行操作,注意MASTER_USER、MASTER_PASSWORD的值需要与主库设置的值相同。

主从同步实践

主库进行操作,观察从库变化。

主库新建数据库hello

主库创建hello数据库后,从库刷新一下,在从库中也看到了hello数据库。

对主库的所有操作,都会实时同步到从库,包括建表,数据更新等操作。

主动同步就这样创建好了。

注意事项?

网络要求,主从数据库网络互通。

主从数据库的版本要一致,否则可能会出现版本兼容问题。通过select VERSION();命令查询数据库版本号。

主从数据库的server-id不能相同,会冲突,在数据库配置文件my.ini中可以修改。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/10 14:15:55

17、Yocto项目软件层与应用开发指南

Yocto项目软件层与应用开发指南 1. SMACK规则与软件许可 SMACK(Security Modules for Linux)规则存储在 /etc/smack/accesses 文件中,格式如下: <subject-label> <object-label> <accesses>可使用 smackload 工具加载规则,该工具会格式化数据并…

作者头像 李华
网站建设 2026/2/10 13:44:11

22、应用开发:库构建与Linux帧缓冲使用指南

应用开发:库构建与Linux帧缓冲使用指南 在软件开发过程中,库的构建和使用是非常重要的环节,同时,利用Linux帧缓冲进行图形和视频显示也有其独特的应用场景。下面将详细介绍静态库、动态库的构建方法,以及如何使用Linux帧缓冲。 1. 共享库相关知识 对于给定的 libexamp…

作者头像 李华
网站建设 2026/2/7 10:32:46

EmotiVoice情感语音合成原理剖析:编码器与解码器协同机制

EmotiVoice情感语音合成原理剖析&#xff1a;编码器与解码器协同机制 在虚拟偶像的直播中&#xff0c;观众的一句“太感动了”弹幕刚出现&#xff0c;主播的声音立刻从欢快转为温柔低语&#xff1b;有声书里&#xff0c;主角遭遇背叛时语气骤然颤抖&#xff0c;仿佛真实情绪涌上…

作者头像 李华
网站建设 2026/2/4 2:13:42

28、Python 环境管理与进程处理全解析

Python 环境管理与进程处理全解析在 Python 开发中&#xff0c;环境管理和进程处理是非常重要的部分。本文将详细介绍虚拟环境管理工具 virtualenv 和 EPM 包管理器&#xff0c;以及 Python 中的 subprocess 模块在进程处理方面的应用。1. virtualenv&#xff1a;创建隔离的 Py…

作者头像 李华
网站建设 2026/2/8 19:38:18

如何快速实现图像压缩:Compressor.js完整使用指南

如何快速实现图像压缩&#xff1a;Compressor.js完整使用指南 【免费下载链接】compressorjs compressorjs: 是一个JavaScript图像压缩库&#xff0c;使用浏览器原生的canvas.toBlob API进行图像压缩。 项目地址: https://gitcode.com/gh_mirrors/co/compressorjs Compr…

作者头像 李华