微服务之并行与分布式计算

一、概述

1.1集中式系统vs分布式系统

集中式系统

集中式系统完全依赖于一台大型的中心计算机的处理能力,这台中心计算机称为主机(Host mainframe ),与中心计算机相连的终端设备具有各不相同非常低的计算能力。实际上大多数终端完全不具有处理能力仅作为输入输出设备使用

伴随着大型主机时代的到来,大型主机卓越的性能和良好的稳定性,其 在单机处理能力方面的优势非常明显,使得IT 系统快速进入了集中式处理阶段
集中式系统最大的 特点 就是 部署结构简单
由于集中式系统往往基于底层性能卓越的大型主机,因此 无须考虑如何 对服务进行多个节点的部署,也就不用考虑多个节点之间的分布式协作 问题
20 世纪 80 年代以来,计算机系统向网络化和微型化的发展日趋明显, 传统的集中式处理模式越来越不能适应人们的需求。主要缺点:
• 学习成本高
• 价格高
• 单点故障
• 扩展困难

分布式系统

分布式系统的理论出现于 20 世纪 70 年代,而随着社交网络、移动互联网、 电子商务等技术的不断发展,互联网的使用者贡献了越来越多的数据。为了处理这些数据,每个互联网公司在后端都有一套成熟的分布式系统 用于数据的存储、计算以及价值提取。
与集中式系统相反,分布式系统中,多个通过网络互联的计算机都具 有一定的计算能力,他们之间通过网络互相传递数据,实现信息共享, 协作共同完成一个处理任务。
分布式系统的特性或是 优势包括容错性、高可扩展性、开放性、并发处理能力和透明性

分布式系统的关键问题
分布式系统虽然相较于集中式系统而言具备优势,但同时也存在一些不 得不考虑的问题:
1 )网络传输的三态 : 如何使通信的代价降到用户可以忍耐的层次是分 布式系统设计的重要目标。
2 )异构性:分布式系统由于基于不同的网络、操作系统、软件实现技术体系,必须要考虑一种通用的服务集成和交互方式来屏蔽异构系统之 间的差异
3 )负载均衡:提高系统的整体效率和吞吐量,必须考虑最大程度发挥 每个节点的作用
4 )数据一致性:数据被分散或者复制到不同的机器上,如何保证各台 主机之间的数据一致性将成为一个难点
5 )服务可用性:分布式系统要设计成允许出现部分故障而不影响整个系统的正常可用

1.2计算模式

并行计算

并行计算的基本思想是被求解问题分解成若干个部分,用多个处理器来 并行的求解每部分,并协同得到问题的最终解。并行计算最初强调多处理器间的并行,所有处理器或是紧耦合于中心共享内存或是松耦合于分布式内存。并行计算的实现多是在集中式的大型计算机内部基于多核 CPU、众核 GPU 等处理部件的指令级、线程级并行。 而随着网络的发展,并行计算设计也已经延伸到基于网络互连的若干独立计算机构成的集群之间的任务级并行。
技术: 时间并行(流水线)、空间并行(指令并行、线程并行
编程: MPI OpenMP CUDA

分布式计算

分布式计算的基本思想是将一个程序被分成多个部分,分布在通过 网络连接起来的多台计算机上运行。分布式系统强调的是由众多自治的计算机组成,各自拥有其私有内存,通过计算机网络通信,以消息传递 的方式完成信息交换。分布式计算的实现可以基于大型数据中心的成百 上千台服务器,甚至也可以基于分布在世界各地的服务器。分布式计算 在广义的定义上范围很广,包括网格计算、P2P 计算等。

并行计算常被拿来与分布式计算想比较。它们在设计目标、计算粒度、 关键技术、任务耦合度等方面有所不同。但随着网络的发展,二者之间 的界限已经越来越模糊,分布在多台计算机的任务实质上也是在并行执行
并行计算、分布式计算的困境
并行计算机:价格高,个人中小企业难以承担
分布式集群:要求计算机数量大,个人中小企业同样不具备

云计算

美国国家标准技术学院(NIST ):云计算是一种模型,这个 模型可以方便地通过网络访问一个可配置的计算资源(例如 网络、服务器、存储设备、应用程序以及服务等)的公共集。 这些 资源可以被快速提供 并发布,同时 最小化管理成本 以及 服务供应商的干预
提供哪些服务?
基础设施( IaaS
平台( PaaS
软件( SaaS

1.3计算模式与大数据的关系

结论:
处理能力是大数据发展的基石,没有足够强大的处理能力, 大数据将毫无价值。
而大数据又反过来推动着计算技术的发展。 促进计算模式 的变革

1.4历史发展

平台变革

基于网络的系统技术

  • 多核CPU和多线程技术(单节点计算能力提升技术)
    • 先进的 CPU 处理器
    • 多核 CPU 和众核 GPU 体系结构
    • 多线程技术
  • 大规模和超大规模 GPU 计算
  • 内存、外部存储和广域网
    •  . 内存和磁盘
    • 系统区域互联
    • 广域网
  • 虚拟机和虚拟化中间件
    • 虚拟机

1.5分布式和云计算系统模型

大系统被划分为4组:集群、P2P、计算网格、大数据中心之上的互联网云

协同计算集群

计算集群由互连的协同工作的独立计算机组成,这些独立计算机作为单一集 成的计算资源协同工作。集群式的计算机系统在处理重负载大数据集任务方面已经发挥了重要作用。Top500 超级计算机中,多数采用集群体系结构构建。

主要的集群设计问题
没有一个适合集群的完全资源共享的操作系统。软件环境和应用依靠 中间件来达到高性能

网格计算基础设施

网格计算 被 预想用于同时在多台远距离计算机上运行的应用间进行近距离交互

对等网络

客户端服务器体系结构。客户机( PC 和工作站)被连接到一个中央服务器, 用来进行计算、电子邮件、文件访问和数据库应用。P2P 体系结构提供了一 个分布式的网络化系统模型

P2P系统

在一个 P2P 系统中,每个节点既是客户端又是服务器,提供部分系统资源。
节点机器都是简单的接入互联网的客户机。所有客户机自治、自由地加 入和退出系统。不存在主从关系。
无需中心协作或中心数据库。系统是分布式控制下自组织的。

P2P 挑战
硬件、软件、网络异构性
容错、失效管理和负载均衡
安全、隐私和版权(商业应用的主要问题)
无中心,管理困难

互联网上的云计算

1.6计算模式的区别

并行计算

目前流行的高性能并行计算机系统结构通常可以分成以下 5 类:
并行向量处理机( PVP
对称式共享存储器多处理机( SMP
分布式共享存储器多处理机( DSM
大规模并行处理机( MPP
机群计算机( Cluster )( COW

分布式计算

网格计算

云计算

边缘计算

算力网络

二、并行编程基础(了解)

2.1并行计算机体系结构

Flynn分类法

.并行计算机系统

2.2OpenMP

什么是 OpenMP
OpenMP 是一种用于 共享内存 并行系统的多线程程序设计方案,支持的编 程语言包括C C++ Fortran
OpenMP 提供了对并行算法的高层抽象描述,特别适合在多核 CPU 机器上 的并行程序设计。编译器根据程序中添加的pragma 指令,自动将程序并 行处理,并在必要之处加入同步互斥以及通信,使用OpenMP 降低了并行 编程的难度和复杂度。当编译器不支持OpenMP 时,程序会退化成普通 (串行)程序。程序中已有的OpenMP 指令不会影响程序的正常编译运行。

OpenMP指令

OpenMP指导指令

OpenMP子句

规则:
- 区分大小写;
- 指令遵循 C/C++ 编译器指令标准的约定;
- 每个指令只能指定一个指令名;
- 每个指令最多应用于一个后续语句,该语句必须是一个结构化块;
- 长指令行可以通过在指令行的末尾使用反斜杠 (“\”) 来转义换行符,
从而在后续的行中“继续

2.3MPI编程

消息传递式并行程序设计
指用户必须通过显式地发送和接收消息来实现处理机间的数据交换。在 这种并行编程中,每个并行进程均有自己独立的地址空间,相互之间访 问不能直接进行,必须通过显式的消息传递来实现。这种编程方式是 大 规模并行处理机(MPP )和机群( Cluster )采用的主要编程方式
并行计算粒度大,特别适合于大规模可扩展并行算法用户决定问题分解
策略、进程间的数据交换策略,在挖掘潜在并行性方面更主动 , 并行计算
粒度大 , 特别适合于大规模可扩展并行算法

2.4CUDA编程

 Numba

Numba 库了 Python CPU GPU 编程工具,速度比原生 Python 快数十倍甚 至更多。Numba 还提供了一个 GPU 模拟器,即使暂时没有 GPU 机器,也可以先使用这个模拟器来学习GPU 编程。

三、分布式通信

3.1通信节点

分布式系统的本质是利用多台计算机构成计算集群,每个节点的运 算结果最终需要汇集在一起才能支撑起分布式系统庞大的运算量。因此, 进程间的通信是一切分布式系统的核心。没有通信机制,分布式系统的 各个子系统将是“一盘散沙”,毫无作用

在分布式系统中, 节点是指一个可以独立按照分布式协议完成一组逻辑 的程序个体,是一个完整的、不可分的整体,是执行分布式任务的最小单元
程序往往会部署到不同的节点中,不同节点之间需要通过网络进行通信。 在具体的工程项目中,一个节点往往是操作系统上的一个进程,甚至线 程。

在分布式系统中,两个或多个进程按约定的某种协议进行 IPC ,此处协议 是指数据通信各参与进程必须遵守的一组规则。在协议中,一个进程有些时候可能是发送者,在其他时候则可能是接收者。

IPC 的四种基本操作
发送( Send ):该操作由发送进程发起,旨在向接收进程传输数据。
操作必须允许发送进程识别接收进程和定义待传数据。
接收( Receive ):该操作由接收进程发起,旨在接收发送进程发来的
数据操作必须允许接收进程识别发送进程和定义保存数据的内存空间,
该内存随后被接收者访问。
连接( Connect ):对面向连接的 IPC ,必须有允许在发起进程和指定
进程间建立逻辑连击的操作:其中以进程发出请求连接操作而另一进
程发出接受连接操作。
断开连接( Disconnect ):对面向连接的 IPC ,该操作允许通信的双方
关闭先前建立起来的某一逻辑连接

3.2网络基础

分布式系统可以总结为是处于不同物理位置的多个进程组成的整体,为了确保这个整体有效并且高效的对外提供服务,每个节点之间都有可能 需要进行通信来交换信息。
而交换信息需要解决两个问题,
如何定位网络上的一台或多台主机
定位后如何进行数据的传输

1)如何定位网络上的一台或多台主机

IP 地址是唯一标识网络上的一台计算机(通信实体),网络中的域名都 对应着某一个IP 地址。
端口号是标识正在计算机上运行的进程(程序)不同的进程有不同 的端口号,用16 位的二进制表示,即 0-65535 之间。常见的有 tomcat 的 8080端口, mysql 3306 端口。
IP 地址和端口号的组合,叫做网络套接字( Socket )。进程之间的通信需 要借助IP 地址和端口号,即网络套接字( Socket )来实现通信节点的定位。

2)找到主机后如何可靠高效地进行数据传输

需要通过 TCP/UDP 等协议进行数据传输。
网络协议就是一种通信双方共同遵循的约定。网络数据传输中,在网络 上经过的的网络节点都要遵循约定和规则,比如传输数据的格式。

 

TCP与UDP协议

端口(重要)

进程的创建和撤销都是动态的,因此发送方几乎无法识别其他机器上的 进程。
我们往往需要利用目的主机提供的功能来识别终点,而不需要知道具体 实现这个功能的进程是哪一个。
有时我们会改换接收报文的进程,但并不需要通知所有的发送方。

Socket

Socket 是对网络中不同主机上的应用进程之间进行双向通信的 端点的抽象
一个套接字就是网络上进程通信的一端,提供了应用层进程利用网络协 议交换数据的机制。从所处的地位来讲,套接字上联应用进程,下联网 络协议栈,是应用程序通过网络协议进行通信的接口,是应用程序与网 络协议进行交互的接口。
Socket 的表示包括:连接协议,本地主机的 IP 地址,本地进程的协议端口, 远地主机的IP 地址,远地进程的协议端口

代码举例

相关概念

I/O 模型
Socket 封装了底层的 TCP UDP 等传输协议,建立了节点间通信的通道。 I/O模型决定了 用什么样的通道 进行输出的发送和输入的接收,很大程度 上决定了通信的性能。

阻塞与非阻塞通信

同步与异步通信

BIO

NIO

Buffer

Channel

Selector

AIO

3.3RPC概述

RPC Remote Procedure Call )是指计算机 A 上的进程,调用另外一台计 算机 B 上的进程,其中 A 上的调用进程被挂起,而 B 上的被调用进程开 始执行,当值返回给 A 时, A 进程继续执行。 调用方可以通过使用参数 将信息传送给被调用方,而后可以通过传回的结果得到信息。 而这一过
程,对于开发人员来说是透明的。

RPC 调用采用客户机 / 服务器 (C/S) 模式。请求程序就是一个客户机,而服 务提供程序就是一台服务器。和常规或本地过程调用一样,远程过程调 用是同步操作,在远程过程结果返回之前,需要暂时中止请求程序。

1 )序列化
序列化是将数据结构或对象转换成二进制串的过程。序列化后的二进制 数据才能通过底层网络进行传输。不同的序列化协议在性能和空间开销 上都有所不同。序列化后的字节数据体积越小,网络传输的数据量就越 小,速度也更快。在接到字节序列后,还要进行反序列化操作,将二进 制字节流转换成对象。
常用的序列化方案包括: JDK 原生的序列化方案、 Protobuf JSON 、 Hessian、 XML 等。
(2)其它模块:服务发现
除了序列化与网络传输两个核心模块外,服务发现通常是必备模块。 客户端在做远程过程调用时,首先需要发现远程主机上可调用的服务。 实现方式是创建服务注册中心。服务端所有可调用的函数、对象都需要 在服务注册中心注册,客户端需要从注册中心处获得可调用的服务对象。 为了提升注册中心的可用性,避免单点故障,有些RPC 方案中还采用 Zookeeper集群作为注册中心

3.4RMI概述

RMI Remote Method Invocation 的缩写,即远程方法调用。 RMI RPC 模 型的面向对象实现,是 一种用于实现远程过程调用的应用程序编程接口 , 它使客户机上运行的程序可以调用远程服务器上的对象。

RMISocket的比较

远程方法调用 API 作为分布式对象计算范型的代表,是构建网络应用的有 效工具。它可用来取代socket API 快速构建网络应用。在 RMI API socket API之间权衡时,需要考虑以下因素:
1 socket API 的执行与操作系统密切相关,因此执行开销更小, RMI 需要额外的中间件支持,包括代理和目录服务,这些不可避免地带来运行时 开销。对有高性能要求的应用来说,socket API 仍将是惟一可行途径。
2 RMI API 提供了使软件开发任务更为简单的抽象。用高级抽象开发的 程序更易理解,因此也更易调试
3 )由于运行在低层, socket API 通常是平台和语言独立的, RMI 则不一定。 例如Java RMI 需要特定的 Java 运行时支持。结果是,使用 Java RMI 实现的 应用必须用Java 编写,并且也只能运行在 Java 平台上。
4 )在设计应用系统时,是否能选择适当的范型和 API 是非常关键的。依 赖于具体环境,可以在应用的某些部分使用某种范型或API ,而在其他部 分使用另一种范型或API 。由于使用 RMI 开发网络应用相对简单, RMI 是快 速开发应用原型的一个很好的候选工具。

四、分布式系统的一致性

4.1一致性的产生

虽然分布式系统有着诸多优点,但也存在着诸多需要解决的问题,一致 性问题就是其中的关键问题。分布式系统中的一致性问题通常发生在两 种场景中。
1 )数据复制
2 )分布式事务

.数据复制

复制机制的目的是为了保证数据的一致性。但是数据复制面临的主要难题也是如何保证多个副本之间的数据一致性。
在分布式系统引入复制机制后,不同的数据节点之间由于网络延时等原 因很容易 产生数据不一致的情况。

分布式事务

分布式事务举例

4.2一致性级别

为了更好地描述客户端一致性模型,通过模拟一个应用场景来说明,这 个场景包以下组成部分。
存储系统:存储系统可以理解为一个黑盒子,他提供了可用性和持久 性的保证。
进程 A B C :三个进程相互独立,能够实现对存储系统的 wirte 和 read操作。

强一致性

保证当更新操作完成之后,任何多个后续进程或者线程的访问都会返回 最新的更新过的值。这种是对用户最友好的,就是用户上一次写什么, 下一次就保证能读到什么

在示例场景中,假如 A 写入了一个值到存储系统,存储系统保证后续 A 、 B、 C 的读取都为最新值

弱一致性

系统并不保证进程或者线程的访问都会返回最新的更新过的值。系 统在数据写入成功之后,不承诺立即可以读到最新写入的值,也不会具 体的承诺多久之后可以读到。但会尽可能保证在某个时间级别(比如秒 级别)之后,可以让数据达到一致性状态。

在示例中,假设 A 写入一个值到存储系统,存储系统不能保证后续 A B 、 C的读取操作能读取到最新值。此情况下有一个时间窗口的概念,它特指 从A 写入值,到后续操作 A B C 读取到最新值这一段时间。

最终一致性

弱一致性的特殊形式。系统保证在没有后续更新的前提下,系统最终返回上一次更新操作的值。在没有故障发生的前提下,不一致窗口的时间主要受通信延迟,系统负载和复制副本的个数影响。
假如 A 首先写了一个值到存储系统,存储系统保证如果 A B C 后续读取 之前,没有其他写操作更新同样的值的情况下,最终所有读取操作都会 读取到A 写入的最新值。 DNS 是一个典型的最终一致性系统,当更新一个 域名的ip 以后,根据配置策略以及缓存控制策略的不同,最终所有的客 户端都会看到最新的值

4.3事务一致性

ACID ,是指在数据库管理系统( DBMS )中,事务 (transaction) 所具有的四 个特性:原子性(Atomicity )、一致性( Consistency )、隔离性 (Isolation ,又称独立性)、持久性( Durability )。

原子性

一致性

隔离性

持久性

数据库 ACID 原则在 单台服务器 就能完成任务的时代,很容易实现,但是 现在面对如此庞大的访问量和数据量,单台服务器已经不可能适应了, 而ACID 在集群环境下几乎不可能达到人们的预期,保证了 ACID ,效率就 会大幅度下降,为了达到这么高的要求,系统很难扩展,因此就出现了 CAP理论和 BASE 理论。

4.4CAP理论

一个分布式系统最多只能同时满足一致性( Consistency )、可用性 (Availability )和分区容错性( Partition tolerance )这三项中的两项。

一致性

一致性指“ All nodes see the same data at the same time” ,即更新操作成 功并返回客户端完成后,所有节点在同一时间的数据完全一致。对于一 致性,可以分为从客户端和服务端两个不同的视角来看。
从客户端来看,一致性主要指多并发访问时更新过的数据如何获取的问题。
从服务端来看,则是如何将更新复制分布到整个系统,以保证数据的最终一致性问题。

可用性

.分区容错性

CAP权衡 应用

4.5BASE理论

BASE 是指基本可用( Basically Available )、软状态( Soft State )、最终 一致性( Eventual Consistency

1 基本可用(Basically Available

软状态( Soft State

最终一致性( Eventual Consistency

最终一致性是指系统中的所有数据副本经过一定时间后,最终能够达到 一致的状态。
弱一致性和强一致性相反,最终一致性是弱一致性的一种特殊情况。

4.6一致性算法

在分布式系统中,为了保证数据的高可用,通常会将数据保留多个副本 (replica),这些副本会放置在不同的物理的机器上。为了对用户提供正确 的增\ \ \ 查等语义,需要保证这些放置在不同物理机器上的副本是一 致的。

相关概念

二阶段提交

二阶段提交 (Two-phaseCommit) 是指,在计算机网络以及数据库领域内, 为了使基于分布式系统架构下的所有节点在进行事务提交时保持一致性 而设计的一种算法

准备阶段

事务协调者 ( 事务管理器 ) 给每个参与者 ( 资源管理器 ) 发送 Prepare 消息,每 个参与者要么直接返回失败( 如权限验证失败 ) ,要么在本地执行事务,写 本地的redo (记录每条新增或者修改后的数据)和 undo (记录需要回滚 的数据)日志,但不提交

提交阶段

如果协调者收到了参与者的失败消息或者超时,直接给每个参与者发送 回滚(Rollback) 消息;否则,发送提交 (Commit) 消息;参与者根据协调者 的指令执行提交或者回滚操作,释放所有事务处理过程中使用的锁资源。 (注意 : 必须在最后阶段释放锁资源 )

二阶段提交的缺点

三阶段提交

五、共识算法

5.1概述

  • 一致性(consistency)往往指分布式系统中多个副本对外呈现的数据 的状态。
  • 共识(consensus)则描述了分布式系统中多个节点之间,彼此对某个 状态达成一致结果的过程。
实践中,要保障系统满足不同程度的一致性,核心过程往往需要通过共 识算法来达成。

5.2拜占庭将军问题

拜占庭将军问题 (The Byzantine Generals Problem) 提供了对分布式共识问 题的一种情景化描述,由Leslie Lamport 等人在 1982 年首次发表。事实上, 拜占庭将军问题是分布式系统领域最复杂的容错模型, 它描述了 如何在 存在恶意行为( 如消息篡改或伪造 ) 的情况下使分布式系统达成共识。

两种方案:
口信消息解决方案( A Solution with oral message , O M(m) 算法
签名消息解决方案( A solution with signed message , SM(m) 算法
拜占庭将军问题提供了对分布式共识问题的一种情景化描述,是分布式
系统领域最复杂的模型。现有的分布式共识算法主要可分为两类:
拜占庭容错算法和非拜占庭容错算法。

1. 非拜占庭容错算法
. 拜占庭容错算法

5.3Paxos算法

5.4Raft算法

六、分布式存储

6.1分布式存储的基础

概述

新一代分布式存储系统的设计目标:低成本、大规模
分布式存储系统的技术挑战包括: 数据和状态信息的持久化、数据的自动迁移、 系统的自动容错、并发读写的数据的一致性 等方面。
分布式存储面临的应用场景和数据需求都比较复杂,根据数据类型,可以将 其 分为非结构化数据、结构化数据、半结构化数据三类

结构化数据

半结构化数据

非结构化数据

分布式文件系统blob

在系统的实现层面,分布式文件系统内部按照数据块 (chunk) 来 组织数据,每个数据块的大小相同,每个数据可以包含多个 Blob对象或者定长块,一个大文件也可以拆分成为多个数据块。
分布式文件系统将这些数据块分散存储到分布式存储集群中去, 处理数据的复制、一致性、负载均衡、容错等分布式系统难题, 并将用户对Blob 对象、定长块以及文件的操作映射成为对底层 数据块的操作。

分布式键值(Key-Value)系统

分布式表系统

HBASE

分布式数据库

. 分布式存储的历史
HDFS Google File System

6.2文件存储

单机文件系统

网络文件系统

并行文件系统

分布式文件系统

高通量文件系统

总结

6.3单机存储系统VS分布式存储系统

单机存储系统

单机存储 就是散列表、 B 树等数据结构在机械硬盘、 SSD 等持久化介质上的实现。

存储系统的 数据模型 主要包括三类: 文件 关系 以及 键值模型

分布式存储系统

分布式系统能够将数据分布到多个节点,并在多个节点之间实现负载均衡。
其方式主要有两种:
散列分布, 如一致性散列,代表系统为 Amazon Dynamo 系统;
顺序分布, 即每张表格上的数据按照主键整体有序,代表系统为 Google的 Bigtable

6.4数据分区与复制

数据分区(分片)与数据复制是紧密联系的两个概念,对于海量数据, 通过数据分片实现系统的水平扩展 ,而通过 数据复制来保证数据的高可 用性

数据的分区

分布式存储的一个好处是实现了可扩展性,能够存储和处理比单台机器 所能容纳的大得多的数据集。而实现可扩展性的重要方式之一是对数据 进行分区。
分区是指讲一个数据集拆分为多个较小的数据集,同时将存储和处理这些较小数据集的责任分配给分布式系统中的不同节点。 分区后,可以通过向系统中添加更多节点来增加系统存储和处理数据的规模。
. 分区的分类
垂直分区:对表的列进行拆分,将某些列的整列数据拆分到特定的 分区,并放入不同的表中。
优点:减少了表的宽度,每个分区都包含了其中的列对应的所有行。 垂直分区也称为“行拆分”,每一行数据都要进行拆分。例如可以将包 含text blob 类型的列垂直分区,确保完整性的同时提高了访问性能。
2 )水平分区:对表的行进行拆分,讲不同的行放入不同的表中,所有 在表中 定义的列在每个分区中都能找到,所以标的特性依然得以保留。
例如,一个整年的销售表可以按月拆分成 12 张表,每个分区存储一个月 的数据
水平分区算法
  • 范围分区
  • 哈希分区
  • 一致性哈希

复制

1.单主复制

根据系统以何种方式同步数据,又可将单主复制分为三类:同步复制, 半同步复制,异步复制。
同步复制
异步复制
半同步复制
单主复制的优点
简单易懂,易于实现。
仅在主节点执行并发写的操作,能够保证操作的顺序,避免了在各个节点处理数据冲突这类复杂的情况,这个特性使得单主复制更容易支持事务类操作。
对于大量读请求工作负载的系统,单主复制是可扩展的,可以通过增 加多个从节点来提升读的性能
. 多主复制

无主复制

无主复制指的是完全没有主节点,尽管无主技术在几十年前就出现了, 但直到亚马逊发布了 Dynamo 架构的论文,并在其中使用了无主复制, 才让该技术重新引起广泛关注。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【ARM 裸机】BSP 工程管理

回顾一下上一节:【ARM 裸机】NXP 官方 SDK 使用,我们发现工程文件夹里面各种文件非常凌乱; 那么为了模块化整理代码,使得同一个属性的文件存放在同一个目录里面,所以学习 BSP 工程管理非常有必要。 1、准备工作 新建…

校车车载4G视频智能监控系统方案

一、项目背景 随着社会的快速发展,校车安全问题日益受到人们的关注。为了提高校车运营的安全性,保障学生的生命安全,我们提出了一套校车车载4G视频智能监控系统方案。该系统能够实时监控校车内部和外部环境,及时发现并处理潜在的…

selenium 自动化测试课上实操指南1——百度搜索

1.环境准备 下面的所有资源可以从超星班级资料中下载,机房的同学在收到的文件夹中可以找到文件 非本校同学,免费加入学银在线课程,就可以在资料 根目录 > 02 课件新 > week09 web自动化测试02 里下载本次实操资料 1)安…

【打工日常】云原生之搭建私有化web在线聊天软件LumenIM

一、LumenIM介绍 1.LumenIM简介 Lumen IM 是一个网页版在线聊天项目,前端使用 Naive UI Vue3,后端采用 GO 开发。 2.LumenIM功能 基于 WebSocket 服务做消息即时推送 支持私聊及群聊 支持多种聊天消息类型 例如:文本、代码块、图片及其它类型文件&…

15.接口自动化学习-Mock(挡板/测试桩)

场景: 新需求还未开发时,使用mock提早介入测试,等后边开发后,进行调试 三方接口返回效率低,使用mock技术走通流程 1.mock方式 (1)如果会写django或flask,可以写简单对应的代码 (…

Mysql--基础知识点--0.1--脏读、不可重复读、幻读

1 脏读、不可重复读、幻读 1.1 脏读 如果一个事务读到了另一个事务已修改且未提交的数据,则发生了脏读现象。 1.2 不可重复读 在一个事务里面多次读取同一个数据,若前后两次读到的数据不一致,则发生不可重复读现象。 1.3 幻读 在一个…

redis7 for windows的安装教程

本篇博客主要介绍redis7的windows版本下的安装教程 1.redis介绍 Redis(Remote Dictionary Server)是一个开源的,基于内存的数据结构存储系统,可用作数据库、缓存和消息代理。它支持多种数据结构,如字符串、哈希表、列…

【软考高项】二十六、范围管理基础内容

一、管理基础 产品范围和项目范围 产品范围强调结果,项目范围强调结果 管理的新实践 :需求一直是项目管理的关注重点,需求管理过程结束于需求关闭,即把产品、服务或成果移交给接收方,以便长期测量、监控、实现并维持收…

three.js 学习笔记 | 光线投射技术 - 包围盒(碰撞检测)

文章目录 three.js 学习笔记光线投射技术实现3D场景交互事件 THREE.Raycaster坐标系的转换案例:选中的模型变为红色 包围盒Box3 - 碰撞检测AABB包围盒辅助器Box3Helper案例1:创建AABB包围盒/包围球computeBoundingBox与boundingBox 搭配使用,…

vivado Aurora 8B/10B IP核(1)

Aurora 8B/10B IP 支持 Kintex -7, Virtex -7 FPGA GTP 和 GTH 收发器,Artix -7 FPGA GTP 收发器, Zynq -7000 GTP and GTP 收发器。Aurora 8B/10B IP core 可以工作于单工或者全双工模式。IP CODE的使用也非常简单,支持 AMBA总线的 AXI4-Stream 协议。…

字符串函数及其模拟实现

目录 strlen函数介绍模拟实现 strcpy函数介绍模拟实现 strcat函数介绍模拟实现 strcmp函数介绍模拟实现 strncpy函数介绍模拟实现 strncat函数介绍模拟实现 strncmp函数介绍模拟实现 strtokstrstr函数介绍模拟实现 strerrorperror strlen 函数介绍 函数介绍: 字符串…

Leetcode 17. 电话号码的字母组合

给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。 示例 1: 输入:digits “23” 输出:[“a…

React真的好难用

我发现React就像个宗教一样,网络上总有一群信徒。信徒:React天下第一,谁也不能说他不好。 网络上大佬对React的评价一般有几类: React跟Vue比就是手动档和自动档的区别,高手都开手动档。—— 就一个破打工的&#xf…

cJSON的使用

文章目录 一、CJSON初识二、CJSON解析器基础三、CJSON解析数据JSON解析基础CJSON解析数组数据CJSON解析嵌套数据 五、创建JSON数据 一、CJSON初识 JSON (JavaScript Object Notation)是一种轻量级的数据交换格式,常用于在网络之间传输数据。它是一种文本格式&#…

河南新办灌溉排涝乙级资质预算分析

河南新办灌溉排涝乙级资质的预算分析是一个涉及多方面因素的综合考量。以下是对该预算的详细分析: 首先,人员费用是预算中的重要组成部分。这包括聘请符合资质要求的技术人员、工程师和其他相关人员的薪酬、社保等费用。这些费用会根据所需人员的数量、资…

JavaScript云LIS系统源码 前端框架JQuery+EasyUI+后端框架MVC+SQLSuga大型医院云LIS检验系统源码 可直接上项目

JavaScript云LIS系统源码 前端框架JQueryEasyUI后端框架MVCSQLSuga大型医院云LIS检验系统源码 可直接上项目 云LIS系统概述: 云LIS是为区域医疗提供临床实验室信息服务的计算机应用程序,可协助区域内所有临床实验室相互协调并完成日常检验工作&#xff…

Unity类银河恶魔城学习记录15-5,6 p157 Audio time limiter p158 Area sound

Alex教程每一P的教程原代码加上我自己的理解初步理解写的注释,可供学习Alex教程的人参考 此代码仅为较上一P有所改变的代码 【Unity教程】从0编程制作类银河恶魔城游戏_哔哩哔哩_bilibili​​ AreaSound.cs using System.Collections; using System.Collections.G…

视频输入c++ 调用 libtorch推理

1、支持GPU情况 libtorch 支持GPU情况比较奇怪,目前2.3 版本需要在链接器里面加上以下命令,否则不会支持gpu -INCLUDE:?ignore_this_library_placeholderYAHXZ 2 探测是否支持 加一个函数看你是否支持torch,不然不清楚,看到…

Hive函数详解

Hive 是一个建立在 Hadoop 上的数据仓库基础架构,它提供了类似于 SQL 的查询语言,称为 HiveQL,用于对存储在 Hadoop 分布式文件系统中的数据进行查询和分析。 1.函数简介 Hive会将常用的逻辑封装成函数给用户进行使用,类似于Jav…

Web前端开发 小实训(一) 成绩分类统计

用于学生web前端开发课程实训练习,掌握基本语法和数据类型 实训目的 使用分支语句,完成分数统计与等级对比,通过输入框输入分数,可以根据分数多少划分等级。 参考思路: 分析题目:根据输入分数进行等级划分。 操作过…