MySQL数据库的集群方案

article/2025/11/10 11:44:21

 

1.简介

        我们一般应用对数据库而言都是“读多写少”,也就说对数据库读取数据的压力比较大,有一个思路就是说采用数据库集群的方案: 其中一个是主库,负责写入数据,我们称之为:写库; 其它都是从库,负责读取数据,我们称之为: 读库;

      那么,对我们的要求是:

  • 读库和写库的数据一致;
  • 写数据必须写到写库;
  • 读数据必须到读库;

2.架构

 
从该系统架构中,可以看出:

  • 数据库从之前的单节点变为多节点提供服务
  • 主节点数据,同步到从节点数据
  • 应用程序需要连接到2个数据库节点,并且在程序内部实现判断读写操作

这种架构存在2个问题:

  • 应用程序需要连接到多个节点,对应用程序而言开发变得复杂
    这个问题,可以通过中间件解决,如果在程序内部实现,可使用Spring的AOP功能实现
  • 主从之间的同步,是异步完成,也就意味着这是 弱一致性
    a. 可能会导致,数据写入主库后,应用程序读取从库获取不到数据,或者可能会丢失数据,对于数据安全性要求比较高的应用是不合适的
    b. 该问题可以通过PXC集群解决

3.中间件

     通过上面的架构,可以看出,应用程序会连接到多个节点,使得应用程序的复杂度会提升,可以通过中间件方式解 决,如下:

       

    从架构中,可以看出:

  • 应用程序只需要连接到中间件即可,无需连接多个数据库节点
  • 应用程序无需区分读写操作,对中间件直接进行读写操作即可
  • 在中间件中进行区分读写操作,读发送到从节点,写发送到主节点       

 该架构也存在问题,中间件的性能成为了系统的瓶颈,那么架构可以改造成这样:

 这样的话,中间件的可靠性得到了保证,但是也带来了新的问题,应用系统依然是需要连接到2个中间件,又为应用 系统带来了复杂度。

4.负载均衡

     为了解决以上问题,我们将继续优化架构,在应用程序和中间件之间增加proxy代理,由代理来完成负载均衡的功 能,应用程序只需要对接到proxy即可。为了解决以上问题,我们将继续优化架构,在应用程序和中间件之间增加proxy代理,由代理来完成负载均衡的功 能,应用程序只需要对接到proxy即可。


至此,主从复制架构的高可用架构才算是搭建完成。

5. PXC集群架构

在前面的架构中,都是基于MySQL主从的架构,那么在主从架构中,弱一致性问题依然没有解决,如果在需要强一 致性的需求中,显然这种架构是不能应对的,比如:交易数据。

PXC提供了读写强一致性的功能,可以保证数据在任何一个节点写入的同时可以同步到其它节点,也就意味着可以存 其它的任何节点进行读取操作,无延迟。

架构如下:

6.混合架构

在前面的PXC架构中,虽然可以实现了事务的强一致性,但是它是通过牺牲了性能换来的一致性,如果在某些业务场 景下,如果没有强一致性的需求,那么使用PXC就不合适了。所以,在我们的系统架构中,需要将这两种方式综合起 来,这样才是一个较为完善的架构。


http://chatgpt.dhexx.cn/article/5tLAXYm9.shtml

相关文章

MySQL集群解决方案(1):MySQL数据库的集群方案

1、系统架构存在的问题 在我们的系统架构中,DBserver方面我们只是使用了单节点服务,如果面对大并发,海量数据的存储,显然单节点的系统架构将存在很严重的问题,所以接下来,我们将实现MySQL的集群&#xff0c…

C语言回调函数详解及实例

C语言回调函数详解及实例 回调函数:函数 F1 调用函数 F2 的时候,函数 F1 通过参数给函数 F2 传递了另外一个函数 F3 的指针,在函数 F2 执行的过程中,函数F2 调用了函数 F3,这个动作就叫做回调(Callback&…

回调函数

什么是回调函数? 有以下三点 1、自己创建的函数; 2、没有调用; 3、但是函数执行了(在某个条件下)。 例如: 1.定时器函数 var a 1setItercal( function(){aconsole.log(a)},1000)//延时器var a 1setTimeout( functi…

C++中回调函数的一个简单例子?

回调函数应用实例: 1、定义一个Person类 (Person.h)文件: 注意:在这个类中指定了回调函数,回调函数的执行者,和回调函数指针 重要的是 回调函数和回调函数指针是怎么关联的? 2、…

一个简单的jQuery回调函数例子

欢迎扫码加入Java高知群交流 jQuery回调函数简单使用 比如说,我们想要点击某个按钮后触发事件, 先把一些指定内容给隐藏掉, 然后跳出相关信息的对话框。 如果使用普通的方法, 不用回调函数的话, 会有怎么样的效…

【C语言】回调函数

目录 前言 一、回调函数是什么? 二、使用步骤 1.举例 2.库函数中的例子 3.模拟实现qsort()函数 前言 随着我们对C语言的学习以及对指针更加深入的了解,我们避免不了接触到回调函数,以下是关于回调函数的知识分享。 一、回调函数是什么…

C语言回调函数一个简单的例子

回调函数通俗的解释: 普通函数:你所写的函数调用系统函数,你只管调用,不管实现。 回调函数:系统调用你所写的函数,你只管实现,不管调用。 以下是使用C语言实现回调函数的一个例子&a…

JS回调函数——简单易懂有实例

初学js的时候&#xff0c;被回调函数搞得很晕&#xff0c;现在回过头来总结一下什么是回调函数。什么是JS&#xff1f;&#xff08;点击查看&#xff09; 下面先看看标准的解释&#xff1a; <script language"javascript"> 02 function SortNumber( obj, …

C语言回调函数详解(全网最全)

文章目录 一、函数指针1.概念2,如何用函数指针调用函数3.**函数指针作为某个函数的参数**4.函数指针作为函数返回类型5.函数指针数组6.函数指针总结 二、回调函数1.什么是回调函数2 为什么要用回调函数&#xff1f;3 怎么使用回调函数&#xff1f;4.下面是一个四则运算的简单回…

回调函数(简单易懂)

因为今天又遇到新的回调函数的形式 callback && callback()&#xff1b;所以搜了一下回调函数&#xff0c;发现真的好多人写得好复杂啊&#xff0c;看得我昏昏欲睡还是看不懂&#xff0c;还有看到有的人说是 主函数执行完再去执行回调函数&#xff0c;我顿时无语&…

回调函数的使用(完整例程)

前提是了解函数指针的基本用法&#xff08;定义函数指针以及调用&#xff09;&#xff0c;可以看下面这个帖子&#xff0c;一步到位 函数指针的一个定义和两个调用 实战&#xff08;完整代码例子&#xff09; #include<bits/stdc.h> using namespace std; int add(int …

C语言 - 详解回调函数

回调函数和函数指针 回调函数就是一个通过函数指针调用的函数。如果你把函数的指针&#xff08;地址&#xff09;作为参数传递给另一个 函数&#xff0c;当这个指针被用来调用其所指向的函数时&#xff0c;我们就说这是回调函数。回调函数不是由该函数 的实现方直接调用&#…

【Linux rar,unrar命令安装详细实践】

本教程是参考【1】进行实践的&#xff0c;在实践过程中发现一些问题&#xff0c;因此做了一些补充 实践过程 本安装命令在Linux命令下执行 本人是在pycharm下&#xff0c;连接的远程Linux服务器下创建的一个conda环境中运行Linux命令 参考资料教程代码 1. wget https://www.…

Mac Terminal菜鸟篇之使用unrar解压rar文件

在Mac上的归档工具不能够解压rar文件&#xff0c;这时可以使用终端中的unrar来解决问题。 步骤如下&#xff1a; 1.使用Homebrew安装unrar&#xff08;有关Homebrew的安装和使用见Homebrew&#xff09; $ brew install unrar > Downloading http://www.rarlab.com/rar/unr…

Mac用homebrew安装unrar

原来安装方法 brew install unrar 现在安装方法 brew install rar 安装后软件路径为: /opt/homebrew/Caskroom/rar/6.12/rar 安装后的rar软件包含rar和unrar两个命令 如果用以前旧命令会提示找不到该软件名字&#xff0c;用现在方法可以直接安装rar和unrar命令&#xff…

unrar file.rar 解压rar 问题,找不到unrar 命令。安装rar unrar流程及bug处理

在使用unrar e file.rar 解压时报错&#xff0c;需要安装rar 1.安装流程 1.1 用户 如果是root用户则不需要进行切换用户&#xff0c;否则 切换到root用户下【权限问题】 例如&#xff1a;$su root 1.2 下载 cd 指定路径&#xff0c;eg: cd /export/software wget http://w…

rar和unrar压缩解压

1.检查linux中有没有安装rar或者unrar压缩工具&#xff08;其他的压缩解压工具也一样的检查方法&#xff09; 先创建一个目录&#xff1a;mkdir /home/test 试着压缩&#xff1a;rar a test.rar ---如果可以压缩成功&#xff0c;则说明已安装了&#xff0c;如果提示找不到rar…

URIError: URI malformed

url中有特殊字符导致出错&#xff0c;进行一次校验替换 checkfilename(filename) {filename String(filename)if (filename.search(%) ! -1) {return filename.split(%).join(%25)} else if (filename.search(?) ! -1) {return filename.split(?).join(%3F)} else if (fil…

python解压rar文件(利用unrar)win10下教程

最近写爬虫时想把rar文件解压&#xff0c;rarfile一直报错“系统找不到指定文件”&#xff0c;然后就上网查了很多&#xff0c;都没有相应的解决方案&#xff0c;最后利用unrar模块解决解压问题&#xff0c;rarfile还是用不了&#xff0c;那咱们就给大家分享一下unrar的使用方法…

Linux安装unrar

Linux中unrar的安装 下载unrar wget https://www.rarlab.com/rar/rarlinux-x64-6.0.2.tar.gz解压文件 tar xf rarlinux-x64-6.0.2.tar.gz安装 tar -zxvf rarlinux-x64-6.0.2.tar.gz cd rar make make install 解压报错时 rar: /lib/ld-linux.so.2: bad ELF interpreter: N…