基于“Galera+MariaDB”搭建多主数据库集群的实例

1、什么是多主数据库集群

多主数据库集群是一种数据库集群架构,每个节点都可以接收写入操作和读取操作,并且通过心跳机制同步数据,保证数据一致性和高可用性。因多主数据库集群每个节点都可以承担读写操作,因此它可以充分利用各个节点的服务器资源,不存在主备数据库集群那样,备库只承担备份复制而不承担业务请求,使得备库所在的服务器资源处于近乎“闲置”的状态。

2、多主数据库集群和主备数据库集群的优缺点对比

主备数据库和多活数据库是两种常见的数据库架构,它们各有优缺点。
主备数据库的优点:

  • 简单:主备数据库架构相对简单,易于理解和实现;
  • 成本较低:主备数据库架构的成本相对较低,因为只需要两台数据库服务器,一台为主服务器,一台为备用服务器;
  • 数据安全:主备数据库架构可以保证数据的安全性,因为数据会定期从主服务器复制到备用服务器。

主备数据库的缺点:

  • 可用性:如果主服务器出现故障,备用服务器需要接管主服务器的任务,这可能会导致一定的延迟;
  • 性能:由于主备数据库架构只有一台主服务器,如果主服务器出现故障,所有读写请求都需要转移到备用服务器上,这可能会导致性能下降。

多活数据库的优点:

  • 高可用性:多活数据库架构可以保证高可用性,因为多个节点都可以处理读写请求;
  • 负载均衡:多活数据库架构可以实现负载均衡,将读写请求分散到多个节点上,提高性能;
  • 容错性:如果某个节点出现故障,其他节点可以继续提供服务,保证系统的可用性。

多活数据库的缺点:

  • 复杂性:多活数据库架构相对复杂,需要解决数据一致性、冲突处理等问题;
  • 成本较高:多活数据库架构需要更多的数据库服务器和网络设备,成本相对较高;
  • 数据一致性:在多活数据库架构中,数据一致性是一个重要的问题,需要采用各种技术手段来保证。

3、基于“Galera+MariaDB”搭建多主数据库集群示例

3.1、实验拓扑

本文将演示“Galera+MariaDB”多活数据库集群搭建的简单实例,拓扑如下:
在这里插入图片描述
在设计“Galera+MariaDB”这样的技术组合时,为防止上线后在运行过程中出现节点和节点之间数据不一致(脑裂)情况的发生,根据Galera的官方文档,通常建议节点数应当设计为奇数个数据库节点,但如果因为实际的环境或者成本受限等原因无法部署奇数个数据库节点时,就可以考虑单独部署一个Galera Arbitrator节点。
Galera Arbitrator本身不参与复制,但它和其他节点一样也会接受数据,Galera Arbitrator是集群中的一份子,因此它被视为仲裁节点,可以参与投票。

3.2、搭建方式的实现

3.2.1、Galera+MariaDB节点1部署步骤(OpenEuler22.03LTS)

(1)配置好OpenEuler22.03LTS的官方源或者镜像源,并关闭SELinux,通过命令“yum install mariadb-server mariadb-server-galera galera”安装基础软件;
在这里插入图片描述
(2)输入命令“systemctl start mariadb”启动MariaDB数据库;
(3)通过“mysql_secure_installation”命令对该节点的MariaDB数据库进行初始化;
(4)根据实际的业务系统情况创建用户,并授予相应的权限,在本实验环境下,我们创建一个名为“yanmuhuan”的用户,并赋予所有的权限和允许远程访问;
在这里插入图片描述

(5)输入命令“systemctl stop mariadb”停止MariaDB数据库;
(6)输入命令“vim /etc/my.cnf.d/mariadb-server.cnf”,修改mariadb-server.cnf文件,在“[galera]”下,添加如下内容:

wsrep_on=ON
wsrep_provider=/usr/lib/galera/libgalera_smm.so
wsrep_cluster_address=gcomm://192.168.174.131,192.168.174.132
wsrep_cluster_name=rvsdb
wsrep_node_name=db2
wsrep_node_address=192.168.174.131
binlog_format=row
default_storage_engine=InnoDB
innodb_autoinc_lock_mode=2
wsrep_slave_threads=1
innodb_flush_log_at_trx_commit=0
bind-address=0.0.0.0

在这里插入图片描述

需要注意的是,以上配置参数中,我们需要关注以下几个参数的含义:

  • wsrep_cluster_address:集群所包含的节点IP地址;
  • wsrep_cluster_name:集群名称,集群创建时可任取,但创建完成后要求成员节点的该参数一致;
  • wsrep_node_name:节点名称,集群内不同节点的节点名称应当不同;
  • wsrep_node_address:本节点IP地址
  • default_storage_engine:MariaDB默认使用的数据库引擎,都使用InnoDB,因为Galera只支持InnoDB引擎;
  • bind-address:本节点允许被哪些IP网段访问。
    (7)输入命令“galera_new_cluster”命令,将本节点作为多活数据库集群的主节点启动galera集群进程和MariaDB数据库进程。
    在这里插入图片描述

3.2.2、Galera+MariaDB节点2部署步骤(OpenEuler22.03LTS)

此节点配置方式基本与节点1一致,只是/etc/my.cnf.d/mariadb-server.cnf这个配置文件需要根据实际情况做成如下修改:

wsrep_on=ON
wsrep_provider=/usr/lib/galera/libgalera_smm.so
wsrep_cluster_address=gcomm://192.168.174.131,192.168.174.132
wsrep_cluster_name=rvsdb
wsrep_node_name=db3
wsrep_node_address=192.168.174.132
binlog_format=row
default_storage_engine=InnoDB
innodb_autoinc_lock_mode=2
wsrep_slave_threads=1
innodb_flush_log_at_trx_commit=0
bind-address=0.0.0.0

在这里插入图片描述
最后启动数据库时,通过正常的“systemctl start mariadb”启动数据库,而不用“galera_new_cluster”命令。
在这里插入图片描述

3.2.3、Galera Arbitrator节点部署步骤(debian12)

在debian12系统中,Galera Arbitrator需要单独安装,而OpenEuler和CentOS等红帽系Linux中,Galera Arbitrator则已经集成在galera的rpm标准软件中,无须单独安装。
(1)输入命令“apt install galera-arbitrator-4”安装Galera Arbitrator;
在这里插入图片描述
(2)输入命令“vim /etc/default/garb”修改Galera Arbitrator的配置文件,内容如下;
在这里插入图片描述
(3)输入命令“systemctl restart garb”启动Galera Arbitrator;

(4)通过命令“systemctl status grab”,正常的Galera Arbitrator进程结果,如下:
在这里插入图片描述
(5)输入命令“garbd -a gcomm://192.168.174.132:4567 -g rvsdb -d”加入集群;
在这里插入图片描述

(6)任意节点登录MariaDB,通过“show status like 'wsrep_%”命令,找到wsrep_cluster_size参数,可看到节点数为3(2个MariaDB+1个Galera Arbitrator);
在这里插入图片描述

3.2.4、知识补充:debian12下部署Galera+MariaDB节点与OpenEuler下部署的差别

(1)debian下部署Galera+MariaDB节点的命令为:“apt-get install galera mariadb-server”,这意味着在debian系Linux软件仓库中的MariaDB已经集成了Galera,并不会像OpenEuler等红帽系Linux中需要部署单独的“mariadb-server-galera”版本;
(2)针对于debian下Galera的配置文件,需要在/etc/mysql/conf.d/目录下添加单独的“galera.cnf”(名字可以任意)文件,并添加和红帽系Linux一样,例如以下格式的内容,具体参数根据实际情况修改:

[galera]
wsrep_on=ON
wsrep_provider=/usr/lib/galera/libgalera_smm.so
wsrep_cluster_address=gcomm://192.168.174.129,192.168.174.130
wsrep_cluster_name=rvsdb
wsrep_node_name=db1
wsrep_node_address=192.168.174.129
binlog_format=row
default_storage_engine=InnoDB
innodb_autoinc_lock_mode=2
wsrep_slave_threads=1
innodb_flush_log_at_trx_commit=0
bind-address=0.0.0.0

(3)其余步骤与OpenEuler或CentOS等Linux系统一致。

3.3、结果测试

任意节点登录MariaDB数据库,输入命令“show status like 'wsrep_%';”可查看相应的集群状态。
在这里插入图片描述
其中,应当着重关注以下参数:

  • wsrep_cluster_state_uuid:集群UUID,集群中所有节点此参数相同;
  • wsrep_cluster_size:集群节点数量;
  • wsrep_connected:本节点与集群通信状态。
    其他参数不代表不重要,可以具体查阅相应资料。

4、注意事项

4.1、Galera+MariaDB节点和节点之间的Galera版本和MariaDB要严格匹配

Galera+MariaDB节点和节点之间的Galera版本和MariaDB要严格匹配,否则将出现节点因为版本不匹配的问题无法加入集群,根据实际的实验现场来看,建议节点和节点的Linux操作系统、MariaDB和Galera版本完全一致。而Galera Arbitrator和Galera+MariaDB节点之间的版本匹配则不是这么严格。

4.2、对集群关机维护与重启的标准操作

若要对集群服务器进行关机维护,集群应先停止对外服务,确认数据库没有来自对外的读写操作后进行关机,并应记好关机顺序,维护完成后按关机顺序的相反顺序进行开机,并启动数据库进程,例如,关机顺序为A>B>C,那么开机顺序则为C>B>A,且开机时的C应执行“galera_new_cluster”,后面启动的节点用“systemctl start mariadb”正常启动数据库。

若忘记关机顺序,则在启动之前,应通过命令“cat /var/lib/mysql/grastate.dat”查看“safe_to_bootstrap”字段的数值,若发现有节点的数值为“1”,则首先通过“galera_new_cluster”启动该节点,其他节点用“systemctl start mariadb”正常启动。
在这里插入图片描述
若所有节点的/var/lib/mysql/grastate.dat文件里,safe_to_bootstrap字段都为0,则可以根据实际情况选择一个节点手动将该数值修改为1,而后通过“galera_new_cluster”启动该节点,其他节点用“systemctl start mariadb”正常启动,此方法也是当节点之间数据不一致(脑裂)发生时,强制启动数据库集群恢复业务的方法,但这种方法很可能会造成部分数据的丢失。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/257861.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【无语】Microsoft Edge 浏览器不显示后台返回的数值数据

Microsoft Edge 禁用 JSON 视图 写在前面禁用 JSON 视图 写在前面 遇到一个有意思的事情,在用 Microsoft Edge 浏览器发送请求测试时发现,后端返回的数值数据没有正常展示,而是类似查看源码的结果,只显示了一个行号1,…

java读取含有合并单元格的Excel

java读取含有合并单元格的Excel Excel如下: import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.util.*;import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.…

redis 7.2.3 官方配置文件 redis.conf sentinel.conf

文章目录 Intro解压配置使用等官方配置文件模板redis.conf 仅配置项redis.conf 完整版(配置项注释)sentinel.conf 仅配置项sentinel.conf 完整版(配置项注释) Intro 在下载页面:https://redis.io/download/ 下载最新版本的redis: https://github.com/re…

线上环境如何正确配置 Django 的 DEBUG?

Author:rab Django Version:3.2 Python Version:3.9 目录 前言一、DEBUG True二、DEBUG False三、页面异常解决总结 前言 由于最近在学习 Django 的知识,于是尝试开发了一套 Blog 系统,在本地测试时是页面显示没问题…

STM32/STM8资源节约主义编程方式

STM32/STM8资源节约主义编程方式 在小资源芯片进行代码设计时,如STM32C0系列,STM8系列,因为官方库本身要包含各种场景应用特征的支持,所以会有一些冗余的代码占用更多FLASH空间。当需要实现资源占用最简化设计方式时,…

Java实现一个在windows环境下的文件搜索引擎

以下是一个简单的Java实现的Windows文件搜索引擎的示例代码: import java.io.File; import java.util.ArrayList; import java.util.List;public class FileSearchEngine {public static void main(String[] args) {String searchDirectory "C:/"; // …

在WPF窗口中增加水印效果

** 原理: ** 以Canvas作为水印显示载体,在Canvas中创建若干个TextBlock控件用来显示水印文案,如下图所示 然后以每一个TextBlock的左上角为中心旋转-30,最终效果会是如图红线所示: 为了达到第一行旋转后刚好与窗口…

排序嘉年华———选择排序和快排原始版

文章目录 一.选择排序二.霍尔版快速排序1.单趟思想2.递归多趟3.寻找中间值作为key 一.选择排序 在进行大佬“快排”之前先来一道开胃小菜————选择排序 选择排序是一种简单直观的排序算法,它的基本思想是每一次从待排序的数据元素中选出最小(或最大&…

大型语言模型:RoBERTa — 一种稳健优化的 BERT 方法

slavahead 一、介绍 BERT模型的出现BERT模型带来了NLP的重大进展。 BERT 的架构源自 Transformer,它在各种下游任务上取得了最先进的结果:语言建模、下一句预测、问答、NER标记等。 尽管 BERT 性能出色,研究人员仍在继续尝试其配置&#xff0…

springCould中的Eureka-从小白开始【2】

目录 1.什么是Eureka ❤️❤️❤️ 2. 组件❤️❤️❤️ 3.单机Eureka配置❤️❤️❤️ 4.服务8001服务入住eureka ❤️❤️❤️ 5.消费端80入住到eureka ❤️❤️❤️ 6.集群Eureka配置 ❤️❤️❤️ 7.将Client发布到eureka集群上 ❤️❤️❤️ 8.服务端8002集群搭建…

Python轴承故障诊断 (八)基于EMD-CNN-GRU并行模型的故障分类

目录 前言 1 经验模态分解EMD的Python示例 2 轴承故障数据的预处理 2.1 导入数据 2.2 制作数据集和对应标签 2.3 故障数据的EMD分解可视化 2.4 故障数据的EMD分解预处理 3 基于EMD-CNN-GRU并行模型的轴承故障诊断分类 3.1 训练数据、测试数据分组,数据分ba…

SpringCloud02

1.在项目中,服务之间的调用是怎么实现的? 1.1基于RestTemplate和LoadBalanced注解: RestTemplate是Spring提供的用于访问RESTful服务的客户端。添加LoadBalanced注解后,RestTemplate会成为一个负载均衡的HTTP客户端,它…

云原生系列2-GitLab和Jenkins

1、GitLab类似github,是个私有仓库 1、GitLab安装,至少8G内存4核cpu # 查找Gitlab镜像 docker search gitlab/gitlab-ce # gitlab镜像拉取 docker pull gitlab/gitlab-ce # 查看镜像 docker images # 本机先建3个目录,为了gitlab容器通过挂…

【web安全】密码爆破讲解,以及burp的爆破功能使用方法

前言 菜某总结,欢迎指正错误进行补充 密码暴力破解原理 暴力破解实际就是疯狂的输入密码进行尝试登录,针对有的人喜欢用一些个人信息当做密码,有的人喜欢用一些很简单的低强度密码,我们就可以针对性的生成一个字典,…

轻量级购物小程序H5产品设计经典样例

主要是看到这个产品设计的不错值得借鉴特记录如下: 不过大多数购物app都大致相同,这个算是经典样例,几乎都可以复制,我第一次使用,感觉和顺畅。看上去产品是经过打磨的,布局非常好。内容也很丰富。支持异业…

【Linux】冯诺依曼体系结构与操作系统及其进程

> 作者简介:დ旧言~,目前大二,现在学习Java,c,c,Python等 > 座右铭:松树千年终是朽,槿花一日自为荣。 > 目标:了解冯诺依曼体系结构与操作系统,掌握…

pytorch中nn.Sequential详解

1 nn.Sequential概述 1.1 nn.Sequential介绍 nn.Sequential是一个序列容器,用于搭建神经网络的模块被按照被传入构造器的顺序添加到容器中。除此之外,一个包含神经网络模块的OrderedDict也可以被传入nn.Sequential()容器中。利用nn.Sequential()搭建好…

AWS 知识二:AWS同一个VPC下的ubuntu实例通过ldapsearch命令查询目录用户信息

前言: 前提:需要完成我的AWS 知识一创建一个成功运行的目录。 主要两个重要:1.本地windows如何通过SSH的方式连接到Ubuntu实例 2.ldapsearch命令的构成 一 ,启动一个新的Ubuntu实例 1.创建一个ubuntu实例 具体创建实例步骤我就不…

useConsole的封装,vue,react,htmlscript标签,通用

之前用了接近hack的方式实现了console的封装,目标是获取console.log函数的执行(调用栈所在位置)所在的代码行数。 例如以下代码,执行window.mylog(1)时候,console.log实际是在匿名的箭头函数()>{//这里执行的} con…

通过https协议访问Tomcat部署并使用Shiro认证的应用跳转登到录页时协议变为http的问题

问题描述: 在最近的一个项目中,有一个存在较久,并且只在内部城域网可访问的一个使用Shiro框架进行安全管理的Java应用,该应用部署在Tomcat服务器上。起初,应用程序可以通过HTTP协议访问,一切运行都没…