MySQL5.7x 主从复制
原文链接:https://blog.liuzijian.com/post/9f8ede8e-26de-75d6-6347.html
在MySQL中,主从复制(Master-Slave Replication)是一种常用的数据库复制技术,用于将主服务器(Master)的数据实时复制到一个或多个从服务器(Slave)。这有助于负载均衡、备份和高可用性。
前提条件
- 主服务器和从服务器的MySQL版本应兼容(最好相同版本)。
- 所有服务器时钟应该同步,可以使用
NTP确保时间一致性。 - 从服务器初始时的数据要与主服务器一致(可以通过备份恢复的方式实现)。
一、配置主服务器(Master)
编辑主服务器的MySQL配置文件
打开MySQL主服务器的配置文件 my.cnf 。添加或修改以下内容:
[mysqld]
server-id = 1 # 唯一的服务器ID,任意正整数,但需要在集群中唯一
log-bin = mysql-bin # 启用二进制日志,确保日志记录所有数据变更
binlog-do-db = my_database # 要复制的数据库(可以指定多个,也可以省略)
server-id:每个服务器都需要有唯一的server-id。log-bin:启用二进制日志,主从复制就是基于二进制日志的。binlog-do-db:指定要复制的数据库,可以指定多个数据库。省略这行会复制所有数据库。
重启MySQL服务:
sudo systemctl restart mysqld
创建用于复制的用户
在主服务器上登录MySQL并创建一个用于复制的用户。CREATE USER 'slave'@'%' IDENTIFIED BY 'password'; GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%'; FLUSH PRIVILEGES;
这里创建了一个名为
slave的用户,密码为password,并授予了复制权限。获取主服务器的状态信息
在主服务器上运行以下命令,记录输出的信息:SHOW MASTER STATUS;
输出类似以下内容:
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 12345 | my_database | |
+------------------+----------+--------------+------------------+
File:二进制日志的文件名。Position:当前日志的偏移量。这两个值将在配置从服务器时使用。
二、配置从服务器(Slave)
编辑从服务器的MySQL配置文件
打开从服务器的配置文件my.cnf,添加或修改如下内容:
[mysqld]
server-id = 2 # 唯一的服务器ID,与主服务器不同
relay-log = mysql-relay # 中继日志,用于存储从主服务器接收到的日志
重启从服务器的MySQL服务:
sudo systemctl restart mysqld
初始化从服务器
登录从服务器的MySQL,并执行以下步骤来设置复制:
CHANGE MASTER TO
MASTER_HOST='master_ip_address',
MASTER_USER='replicator',
MASTER_PASSWORD='password',
MASTER_LOG_FILE='mysql-bin.000001', -- 从SHOW MASTER STATUS获取的日志文件名
MASTER_LOG_POS=12345; -- 从SHOW MASTER STATUS获取的偏移量
在这里,
master_ip_address是主服务器的IP地址,MASTER_LOG_FILE和MASTER_LOG_POS是前面SHOW MASTER STATUS命令中看到的值。启动复制
在从服务器上启动复制进程:
START SLAVE;
检查复制状态
检查从服务器的复制状态,确保复制正常运行:
SHOW SLAVE STATUS\G;
查看输出中的两个关键字段:
Slave_IO_Running: YesSlave_SQL_Running: Yes
如果这两个值都是
Yes,说明主从复制正常。如果不是,可以检查错误信息并进行排查。
三、测试主从复制
在主服务器上创建一个测试表或插入数据:
USE my_database;
CREATE TABLE test_table (id INT PRIMARY KEY, data VARCHAR(50));
INSERT INTO test_table VALUES (1, 'Test Data');
在从服务器上检查该表是否存在以及数据是否同步:
USE my_database;
SELECT * FROM test_table;
如果能看到相同的表和数据,说明主从复制配置成功。
MySQL5.7x 主从复制的更多相关文章
- MySQL5.6主从复制最佳实践
MySQL5.6 主从复制的配置 环境 操作系统:CentOS-6.6-x86_64 MySQL 版本:mysql-5.6.26.tar.gz 主节点 IP:192.168.31.57 ...
- mysql5.7 主从复制的正常切换【转】
目前环境如下: master server IP:172.17.61.131 slave server IP:172.17.61.132 mysql version: mysql-5.7.21-lin ...
- mysql5.7主从复制--在线变更复制类型【转】
这里说一下关于如何在线变更复制类型(日志复制到全局事物复制),参考课程:mysql5.7复制实战 先决条件 (1)集群中所有的服务器版本均高于5.7.6(2)集群中所有的服务器gtid_mod ...
- MySQL5.6主从复制方案
MySQL5.6主从复制方案 1.主备服务器操作 环境:CentOS 6.3/6.4 最小化缺省安装,配置好网卡. 安装MySQL前,确认Internet连接正常,以便下载安装文件. # 新增用户组 ...
- MySQL5.7Gtid主从复制总是遇到日志被清等出现无法正常主从复制
最近最是在MySQL5.7上的的gtid主从复制问题总是遇上下面问题: Last_Error: Coordinator stopped because there were error(s) in t ...
- Mysql5.6主从复制-基于binlog
MySQL5.6开始主从复制有两种方式:基于日志(binlog):基于GTID(全局事务标示符). 此文章是基于日志方式的配置步骤 环境: master数据库IP:192.168.247.128sla ...
- MySQL5.6主从复制搭建基于日志(binlog)
什么是MySQL主从复制 简单来说,就是保证主SQL(Master)和从SQL(Slave)的数据是一致性的,向Master插入数据后,Slave会自动从Master把修改的数据同步过来(有一定的延迟 ...
- MySQL5.7 主从复制配置
一.主从复制原理 MySQL 主从复制是一个异步的复制过程,主库发送更新事件到从库,从库读取更新记录,并执行更新记录,使得从库的内容与主库保持一致.每一个主从复制的连接,都有三个线程.拥有多个从库的主 ...
- Centos7 下配置mysql5.6主从复制实例(一主两从)
标签:mysql 数据库 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://8941355.blog.51cto.com/89313 ...
- mysql5.7主从复制
1.简介 1.1主从复制 是指建立一个和主数据库完全一样的数据库环境,称为从数据库:主数据库一般是实时的业务数据库,从数据库的作用和使用场合一般有几个: 一是作为后备数据库,主数据库服务器故障后,可切 ...
随机推荐
- RL 基础 | 如何使用 OpenAI Gym 接口,搭建自定义 RL 环境(详细版)
参考: 官方链接:Gym documentation | Make your own custom environment 腾讯云 | OpenAI Gym 中级教程--环境定制与创建 知乎 | 如何 ...
- CF716B Complete the Word 题解
CF716B Complete the Word 题解 分析 首先观察数据范围是 \(50000\),可以考虑 \(O(n)\) 暴力. 在字符串中枚举子串开始的位置 \(i\),然后再枚举 \(i\ ...
- 两个新出的 JavaScript 运算符
在 ECMAScript 2021(ES12)中,JavaScript 引入了新的逻辑赋值操作符 &&= 和 ??=.这些操作符将逻辑运算符与赋值运算符相结合,提供了更加简洁.直观的赋 ...
- http: server gave HTTP response to HTTPS client
出现这问题的原因是:Docker自从1.3.X之后docker registry交互默认使用的是HTTPS,但是搭建私有镜像默认使用的是HTTP服务,所以与私有镜像交时出现以上错误. 这个报错是在本地 ...
- elasticsearch权限验证(Auth+Transport SSL)
转载:https://knner.wang/2019/11/26/install-elasticsearch-cluster-7-4.html 在新版的Elastic中,基础版(免费)的已经提供了基础 ...
- [NET,C# ] Nuget包发布流程
1.新建一个.NET Core类库 2.新增一个方法,并编译项目 3.下载Nuget.exe,与刚才新建的类库放在同一目录下 下载地址:https://www.nuget.org/downloads ...
- 关于Pro addin中,控制dockpane的状态
在Pro SDK中,可以通过dackpane的Hide()方法,对面板进行隐藏. DockPane pane = FrameworkApplication.DockPaneManager.Find(& ...
- LeetCode题集-6 - Z 字形变换
题目:将一个给定字符串 s 根据给定的行数 numRows ,以从上往下.从左到右进行 Z 字形排列. 这一题作为中等难度,下面和大家分享几种不同的解法. 01.二维矩阵模拟法 所谓二维矩阵模拟法就是 ...
- C/C++源码扫描系列- Joern 篇
文章首发于 https://xz.aliyun.com/t/9277 概述 和 codeql,Fortify 相比 Joern不需要编译源码即可进行扫描,适用场景和环境搭建方面更加简单. 环境搭建 首 ...
- Jackson基本使用教程
目录 如何将一个Json序列化对象封装成为一个Pojo是实体类对象 如何进行序列化与反序列化 如何将数据进行绑定 如何进行泛型数据绑定 如何使用Jackson树模型(将复杂Json手动映射到类型) 使 ...