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

介绍:级联复制架构

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

也就是在级联复制架构中,存在两层从库,这实际上属于一主多从架构的升级版,毕竟如果一个主节点存在多个从节点时,多个从节点都会同时去主节点拉取新数据,如果数据量较大,就会导致主节点的 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://xiahunao.cn/news/2779234.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

Failed to construct ‘RTCIceCandidate‘ sdpMid and sdpMLineIndex are both null

最近在搞webrtc,在编写函数处理远端传递来的candidate时报错了,具体信息如下。国内关于webrtc的资料很少,所以去国外社区转了一圈,回来记录一下报错的解决方案 其实这个bug也好解决,根据报错信息可以判断是RTCIceCand…

C语言第二十二弹---指针(六)

✨个人主页: 熬夜学编程的小林 💗系列专栏: 【C语言详解】 【数据结构详解】 指针 1. 回调函数是什么? 2、qsort使用举例 2.1、使用qsort函数排序整型数据 2.2 使用qsort排序结构体数据 3、qsort函数的模拟实现 总结 1. 回…

龙年,大吉

(1) 没有成功的企业,只有时代的企业。这就是人们老说的:天道酬勤。虽然这句话被人说滥了,虽然这句话被人说到反感了,但事实就是这样。 得道者多助。 (2) 人有三大运、三小运。 三大运…

Python基础语法(内置Python, pycharm配置方式)

一.工具安装与配置 1.Python解释器的安装 官网网址:https://www.python.org/ 选择downloads即可(Windows用户点击Windows, 苹果用户点击macOS) 找到最新版本, 并选择 Download Windows installer (64-bit) 下载完成后可在得到一个安装包进行安装(安装时间较长) 安装完成后…

【JMX】JAVA监控的基石

目录 1.概述 2.MBean 2.1.Standard MBean 2.2.Dynamic MBean 2.3.Model Bean 2.4.Dynamic MBean和Model Bean的区别 2.5.MXBean 2.6.Open Bean 3.控制台 1.概述 什么是JMX,首先来看一段对话: Java Management Extensions(JMX&#…

【Wio Terminal教程】使用LCD屏幕(4)

使用LCD屏幕(4) 一、TFT LCD的API例子1、实用图形2、数据显示3、字体4、作为背景显示 二、如何在Wio Terminal上使用LVGL图形库1、安装Seeed_Arduino_LvGL2、示例1. Bench Mark2. Stress Test3.资源 一、TFT LCD的API例子 本节为TFT LCD库的例子提供了一…

ERROR: Could not build wheels for roslz4

Python bugs 最近在安装python的rosbag包时出现了诸多问题,特别记录下。 python版本:3.11 系统版本:Windows10 x86_64 使用conda虚拟环境进行包管理。 运行命令 pip3 install roslz4 --extra-index-url https://rospypi.github.io/simple…

【数据结构与算法】【小白也能学的数据结构与算法】递归 分治 迭代 动态规划 无从下手?一文通!!!

🎉🎉欢迎光临🎉🎉 🏅我是苏泽,一位对技术充满热情的探索者和分享者。🚀🚀 🌟特别推荐给大家我的最新专栏《数据结构与算法:初学者入门指南》📘&am…

|Python新手小白低级教程之项目篇——turtle库|第一章:turtle库基础(1)

项目篇—文章目录 一、预告二、turtle基础1.导入2.画图代码(1)turtle.forward(长度)练习1.1 画线段 (2)turtle.left()和turtle.right()操作符练习2.1 画出边长为100正方形练习2.2 画出边长为100的三角形 (3&#xff09…

腾讯云4核8G12M轻量应用服务器性能够用吗?支持多少人?

腾讯云轻量4核8G12M轻量应用服务器支持多少人同时在线?通用型-4核8G-180G-2000G,2000GB月流量,系统盘为180GB SSD盘,12M公网带宽,下载速度峰值为1536KB/s,即1.5M/秒,假设网站内页平均大小为60KB…

Web前端-移动web开发_rem布局

文章目录 移动web开发之rem布局1.0 rem基础1.1 rem单位(重点)1.2 em单位(了解)1.3 媒体查询什么是媒体查询媒体查询语法规范 1.4 less 基础维护css弊端Less 介绍Less安装Less 使用之变量使用node编译less的指令Less 编译 vocode Less 插件Less 嵌套Less 运算Less中的Mixin混入L…

车载测试Vector工具——常见问题汇总

车载测试Vector工具——常见问题汇总 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师(Wechat:gongkenan2013)。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何 消耗你的人和事,多看一眼都是你的…

C++重新入门-循环

目录 1.循环类型 while循环: for循环 基于范围的for循环(C11) do...while 循环 2.循环控制语句 3.无限循环 有的时候,可能需要多次执行同一块代码。一般情况下,语句是顺序执行的:函数中的第一个语句先执行,接着…

《零基础实践深度学习》基于线性回归实现波士顿房价预测任务1.3.3

1.3.3 基于线性回归实现波士顿房价预测任务 深度学习不仅实现了模型的端到端学习,还推动了人工智能进入工业大生产阶段,产生了标准化、自动化和模块化的通用框架。不同场景的深度学习模型具备一定的通用性,五个步骤即可完成模型的构建和训练&…

vs2019 - signtool签名和验签的手工操作

文章目录 vs2019 - signtool签名和验签的手工操作概述笔记导入根证书时间戳服务器的选择code sign - 签名文件在代码签名(code sign)前后的区别签名后, 查看属性, 是正常的.用signtool命令行进行验签移除签名END vs2019 - signtool签名和验签的手工操作 概述 signtool是进行c…

linux优化空间完全卸载mysql——centos7.9

文章目录 ⭐前言⭐linux命令使用💖 基础命令💖 内存优化💖 完全删除mysql ⭐结束 ⭐前言 大家好,我是yma16,linux优化空间&完全卸载mysql——centos7.9。 linux内存分配 在Linux中,内存分配是通过几种…

Linux---网络基础

计算机中的常见概念 协议(Protocol): 协议是计算机网络中用于通信的规则和约定的集合。它规定了数据传输的格式、序列、错误检测和纠正方法等。常见的网络协议包括TCP/IP、HTTP、FTP等。 IP地址(IP Address)&#xf…

Python3集合 set 心得

Python3集合 set 心得 本文是个人在学习中的一些心得,不能保证文中的内容准确,欢迎大家批评指正。 集合 set 是Python中的一种数据容器,集合有2种定义方式。 1、花括号 {} ,花括号内加入集合的元素,元素之间用逗号 …

通过Dynamo删除Revit中族参数探究

起因是这样的,有位同事想在项目中直接删除revit族的参数,而不打开族,避免因为重载族,造成一些管件连接断开,于是就有了下面这些研究,当然是因为我没办法实现这个想法,所以这次可以分享下研究的过…

linux系统定时任务管理

crontab使用 一、crontab简介 crontab 这个指令所设置的工作将会循环的一直进行下去!可循环的时间为分钟、小时、每周、每月或每年等。crontab 除了可以使用指令执行外,亦可编辑 /etc/crontab 来支持。 至于让 crontab 可以生效的服务则是 crond 这个服…