news 2026/5/16 18:40:11

MySQL主从复制

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL主从复制

MySQL 主从复制

MySQL主从负载至少需要2台数据库服务器,其中一台为master库,另外一台为slave库,MySQL主从数据同步时一个异步复制的过程,要实现负载首先需要在master 上开启bin-log 日志功能,bin-log日志用于记录在master 库中执行的增、删、修改、更新操作的SQL语句,真个过程需要开启3个现成,分别是master开启IO 线程,slave开启IO线程和SQL 线程,具体主从同步原理如下:

  • slave上执行slave start,slave IO 线程会通过在master 创建的授权用户连接上master,并请求master从指定的文件和位置之后发送bin-log 日志内容;
  • master接收到来着slave IO 线程的请求后,master IO 线程根据slave发送的指定bin-log日志position 点之后的内容,然后返回给slave 的IO 线程
  • 返回的信息中除了bin-log 日志内容外,还有master 最新的bin-log 文件名以及在bin-log中下一个指定更新position 点
  • slave IO线程接收到信息后,将接收到的日志内容依次添加到sloave段的relay-log文件的最末端,并将读取到的master 端的bin-log的文件名和position 点记录到master.info 文件中,一遍在下次读取的时候能告知master从相应的bin-log文件名及最后一个position 点开始发起请求
  • slave SQL 线程检测到relay-log中内容有更新,会立刻解析relay-log 日志中的内容,将解析后的SQL 语句在slave 里执行,执行成功后slave 库与master库数据保持一致

主从复制实现过程:

一、准备2台服务器:
master: 172.17.27.127
slave:172.17.191.75
MySQL 8.0 版本
二、配置主库(master):
1.修改 MySQL 配置文件:/etc/my.cnf

[mysqld]# 唯一服务器IDserver-id=1# 开启 binlog(必须!)log-bin=mysql-bin# MySQL 8.0 推荐设置binlog_format=ROW gtid_mode=ON enforce_gtid_consistency=ON
  1. 重启mysql
systemctl restart mysql

重启mysql 服务时如果报下面的错误,说明没有创建mysql 用户,创建一下mysql用户就可以

[root@master ~]# journalctl -xeDec1314:13:36 nodea100-2 systemd[40128]: Failed at stepUSERspawning /usr/bin/mysqld_pre_systemd: No such process -- Subject: Process /usr/bin/mysqld_pre_systemd could not be executed -- Defined-By: systemd -- Support: http://lists.freedesktop.org/mailman/listinfo/systemd-devel -- -- The process /usr/bin/mysqld_pre_systemd could not be executed and failed. -- -- The error number returned by this process is3. Dec1314:13:36 nodea100-2 systemd[1]: mysqld.service: control process exited,code=exitedstatus=217Dec1314:13:36 nodea100-2 systemd[1]: Failed to start MySQL Server. -- Subject: Unit mysqld.service has failed......[root@master ~]# groupadd -g 27 mysql[root@master ~]# useradd -u 27 -g mysql -s /sbin/nologin -d /var/lib/mysql mysql[root@master ~]# chown -R mysql:mysql /var/lib/mysql[root@master ~]# systemctl restart mysqld
  1. 创建复制专用用户
-- 登录 MySQLmysql-u root-p-- 创建用户(允许从 172.17.191.75 连接)CREATEUSER'repl'@'172.17.191.75'IDENTIFIEDBY'-----';-- 授予复制权限GRANTREPLICATIONSLAVEON*.*TO'repl'@'172.17.191.75';-- 刷新权限FLUSHPRIVILEGES;
  1. 记录当前 bin-log 位置:
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/8 1:13:18

千万不能错过!这款外卖点单小程序让商家效率飙升

千万不能错过!这款外卖点单小程序让商家效率飙升引言随着移动互联网的快速发展,外卖行业已经成为餐饮业不可或缺的一部分。为了提升运营效率和服务质量,越来越多的商家开始采用外卖点单小程序。本文将深入探讨一款高效的外卖点单小程序——妙…

作者头像 李华
网站建设 2026/5/14 20:30:45

tev:终极HDR图像查看器与专业对比工具指南

tev:终极HDR图像查看器与专业对比工具指南 【免费下载链接】tev High dynamic range (HDR) image viewer for graphics people 项目地址: https://gitcode.com/gh_mirrors/te/tev 想要快速高效地查看和比较高动态范围图像吗?tev是一款专为图形专业…

作者头像 李华
网站建设 2026/5/15 19:55:15

Monstercat Visualizer终极指南:打造专属音乐可视化盛宴

还在为单调的音乐播放界面感到乏味吗?想要让每一首歌曲都拥有独特的视觉呈现吗?Monstercat Visualizer就是你的完美答案!这款基于Rainmeter的实时音频可视化工具,能够将音乐转化为令人惊艳的动态视觉效果,让你的桌面变…

作者头像 李华
网站建设 2026/5/10 12:40:17

5分钟快速上手:I.Ming传承字形字体使用全攻略

5分钟快速上手:I.Ming传承字形字体使用全攻略 【免费下载链接】I.Ming I.Ming ( I.明體 / 一点明朝体 / 一點明體 ) 项目地址: https://gitcode.com/gh_mirrors/im/I.Ming I.Ming是一套基于《传承字形部件检校表》推荐字形标准的开源字体项目,采用…

作者头像 李华
网站建设 2026/5/1 6:51:44

准备入行网络安全?先回答这三个问题!不适合的人可能已被“劝退”

一、什么是网络安全? 百度上对“网络安全”是这么介绍的: “网络安全是指网络系统的硬件、软件及其系统中的数据受到保护,不因偶然的或者恶意的原因而遭受到破坏、更改、泄露、系统连续可靠正常地运行,网络服务不中断。” 嗯…是…

作者头像 李华
网站建设 2026/5/1 5:09:10

零基础转行网络安全,这份半年“速通计划”与阶段里程碑请收好

网络安全技术被广泛应用于各个领域,各大企业都在争抢网络安全人才,这使得网络安全人才的薪资一涨再涨,想转行网络安全开发的人也越来越多。而想要顺利转行网络安全开发,首先要学习网络安全技术,那么转行网络安全从何学…

作者头像 李华