案例:三台主机实现 级联复制

2024-02-11 04:28

本文主要是介绍案例:三台主机实现 级联复制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

介绍:级联复制架构

级联复制架构 是一种特殊的主从结构,之前聊到的几种主从结构都只有两层,但级联复制架构中会有三层,关系如下:

也就是在级联复制架构中,存在两层从库,这实际上属于一主多从架构的升级版,毕竟如果一个主节点存在多个从节点时,多个从节点都会同时去主节点拉取新数据,如果数据量较大,就会导致主节点的 I/O 负载过高,因此这种级联复制架构要解决的问题,也就是多个从库会对主库造成太大压力的问题。

这个过程中,第一层从库只有一个节点,它会负责从主库上拉取最新的数据,接着第二层的多个从库会从上一层的从库中拉取数据,这样能够这在从库较多的情况下,尽量降低数据同步对主节点的性能影响。

案例:三台主机实现 级联复制

// 前置工作
yum install mariadb-server -y
systemctl enable --now mariadb// 关闭防火墙 and SELinux
setenforce 0
systemctl disable --now firewalld
# 10.0.0.8 充当 master
# 10.0.0.18 充当级联 slave
# 10.0.0.28 充当 slave
----
// 在 master 主节点实现
[root@master ~] vim /etc/my.cnf.d/mariadb-server.cnf
[mysqld]
server-id=8
log-bin        # 开启二进制日志功能 ( 建议: 加个二进制日志存放路径 )[root@master ~] systemctl restart mariadb
[root@master ~] mysql
MariaDB [(none)]> show master logs;      // 记录二进制位置, 给中间级联从节点使用
+--------------------+-----------+
| Log_name           | File_size |
+--------------------+-----------+
| mariadb-bin.000001 |       330 |
+--------------------+-----------+
1 row in set (0.001 sec)// 创建用户
## 注意: 修改 IP 地址
MariaDB [(none)]> grant replication slave on *.* to repluser@'10.0.0.%' identified by '123456';
[root@slave ~] mysqldump -A -F --single-transaction --master-data=1 > /root/all.sql
[root@master ~] scp /root/all.sql 10.0.0.18:/root    # 拷贝到从节点
[root@master ~] scp /root/all.sql 10.0.0.28:/root    # 拷贝到从节点----
// 在中间级联 slave 从节点实现 ( 必须开启 log_slave_updates 选项 )
[root@slave1 ~] vim /etc/my.cnf.d/mariadb-server.cnf
[mysqld]
server-id=18       # 唯一 ID
log-bin            # 开启二进制日志功能
log_slave_updates  # 级联复制中间节点的必选项 ( MySQL8.0 此为默认值,可以不人为添加 )
read-only          # 只读
[root@slave1 ~] systemctl restart mariadb# 还原数据库
[root@slave1 ~] vim /root/all.sql
CHANGE MASTER TOMASTER_HOST='10.0.0.8',MASTER_USER='repluser',MASTER_PASSWORD='123456',MASTER_PORT=3306,MASTER_LOG_FILE='mariadb-bin.000001',MASTER_LOG_POS=330;[root@slave1 ~] mysql 
MariaDB [(none)]> set sql_log_bin=0;
MariaDB [(none)]> source /root/all.sql
MariaDB [(none)]> show master logs;        // 记录二进制位置, 给第三个节点使用
+--------------------+-----------+
| Log_name           | File_size |
+--------------------+-----------+
| mariadb-bin.000001 |       330 |
+--------------------+-----------+
1 row in set (0.000 sec)MariaDB [(none)]> set sql_log_bin=0;
MariaDB [(none)]> start slave;// 验证当前主节点与中间级联节点的主从复制架构
MariaDB [(none)]> create database db1;        # 主节点
MariaDB [(none)]> show databases;             # 中间级联从节点
+--------------------+
| Database           |
+--------------------+
| db1                |
| information_schema |
| mysql              |
| performance_schema |
+--------------------+
4 rows in set (0.001 sec)// 验证线程
MariaDB [mysql]> show slave status\G
*************************** 1. row ***************************Slave_IO_State: Waiting for master to send eventMaster_Host: 192.168.80.8Master_User: repluserMaster_Port: 3306Connect_Retry: 60Master_Log_File: mariadb-bin.000002Read_Master_Log_Pos: 516Relay_Log_File: mariadb-relay-bin.000002Relay_Log_Pos: 684Relay_Master_Log_File: mariadb-bin.000002Slave_IO_Running: Yes                        # 运行中Slave_SQL_Running: Yes                        # 运行中----   
// 在第三个节点 slave 上实现
[root@slave2 ~] vim /etc/my.cnf.d/mariadb-server.cnf
[mysqld]
server-id=28   # 唯一 ID
log-bin        # 二进制日志功能 ( 非必须 )
read-only      # 只读[root@slave2 ~] systemctl restart mariadb[root@slave2 ~] vim /root/all.sql 
CHANGE MASTER TOMASTER_HOST='10.0.0.18',MASTER_USER='repluser',MASTER_PASSWORD='123456',MASTER_PORT=3306,MASTER_LOG_FILE='mariadb-bin.000001',MASTER_LOG_POS=330;[root@slave2 ~] mysql
MariaDB [(none)]> source /root/all.sql
MariaDB [(none)]> start slave;// 验证线程
MariaDB [(none)]> show slave status\G
*************************** 1. row ***************************Slave_IO_Running: Yes    # 运行正常Slave_SQL_Running: Yes    # 运行正常----                                                    
// "上一步验证如果存在问题"    ( 重要! )
// "解决:" (  重新配置复制关系, 结果直接没有报错, 这个问题也就修复完成了 )stop slave;reset slave;change master to master_host='192.168.80.8', master_user='repluser', master_password='123456', master_port=3306;start slave;
----# 验证级联复制架构 ( 主从复制 )
MariaDB [(none)]> create database db2;    # 主节点
MariaDB [(none)]> show databases;         # 从节点
MariaDB [(none)]> show databases;         # 从节点

这篇关于案例:三台主机实现 级联复制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/698818

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

RabbitMQ消费端单线程与多线程案例讲解

《RabbitMQ消费端单线程与多线程案例讲解》文章解析RabbitMQ消费端单线程与多线程处理机制,说明concurrency控制消费者数量,max-concurrency控制最大线程数,prefe... 目录 一、基础概念详细解释:举个例子:✅ 单消费者 + 单线程消费❌ 单消费者 + 多线程消费❌ 多

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin