关于分布式一致性

一致性(consistency)

说到一致性,我们可能最先想到的数据库里的事务
这里的讨论的是分布式的一致性,事务就简化一下,只考虑Read/Write

先列举一下事务的种类:

  1. 单机的事务:多个复杂事务发生在一个节点上

  2. 分布式的事务a:多个简单事务发生在多个节点上,一个事务只涉及一个节点

  3. 分布式的事务b:多个复杂事务发生在多个节点上,一个事务可能涉及多个节点

这里就考虑2了

参考资料:
http://kaiyuan.me/2018/04/21/consistency-concept/
https://www.codedump.info/post/20220710-weekly-22/
http://zhangtielei.com/posts/blog-distributed-causal-consistency.html
https://qiankunli.github.io/2022/04/06/replica_consistency_level.html

线性一致性(强一致性)

整个系统表现的像一台单机:

  • 只要写成功,所有节点都能读到最新的数据
  • 对所有client而言,仿佛所有操作都是按照实际时间的先后串行化的

怎么实现强一致性?

  1. 写的时候必须等所有节点都同步好了才返回
  2. 读的时候slave去问master要数据

理想的情况:操作的时间域不重叠(P1,P2表示2个发送请求的客户端)

在这里插入图片描述

区间->点:操作成功的时刻就在线段的一个点上,所以我们可以将上图抽象为下面的样子,可以发现系统满足线性一致性(举个反例:如果Read读出来的是2,就不满足了)

在这里插入图片描述

实际的情况:操作的时间域有重叠,但是没关系,因为操作真正成功可以理解为成时间线段里面的一个时间点

也就是说,操作的顺序不是按照提交时的时间来算的,只要时间段有重叠,那么谁先谁后都有可能:比如说下面的情况,可能是W2先完成,也可能是W3先完成

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

例子1:我们来看看下面这个系统是否满足线性一致性:

在这里插入图片描述

可以的:
在这里插入图片描述

例子2:不满足线性一致性的情况:不管我们怎么调整Write2和Write3的顺序,也不可能让后面的Read操作读出2个不同的值
在这里插入图片描述

顺序一致性

只要保证同一个节点内的操作是按序的即可,节点之间的操作顺序可以随便编排

顺序一致性可以理解成一个特殊的因果一致性:同一个节点内的一系列操作中,前后有因果关系

通俗地讲,虽然你9点吃了饭,但是并不一定能及时的传播到我这边,所以我感知到你吃了饭时,可能已经12点了

但是我观察到的你的事件顺序,必须是跟你真实的情况一致的,我不能先看到你吃中饭,再吃早饭

用这个不满足线性一致性的例子:
在这里插入图片描述

重新编排后可以发现满足顺序一致性
在这里插入图片描述

因果一致性

概括:我不能还没看到你的贴子,就先看到评论了

个人认为因果一致性跟顺序一致性是两个维度的

因果不一定满足顺序:虽然你先吃饭再睡觉,但是我可以观察到你先睡觉再吃饭(只要你的吃饭&睡觉只有时间上的先后,没有因果关系)

顺序不一定满足因果:A在大喊一声导致B醒了,但是C可以观察到B先醒了,然后A大喊一声

举个没有保持因果关系例子:

  1. A发了动态1:东西丢了,真倒霉
  2. A发了动态2:东西找到了,真好
  3. B看到了动态1
  4. B看到了动态2
  5. B对A发表评论1:恭喜
  6. C看到了动态1
  7. C看到了评价1,觉得B太损人了(在这步时因果已经出问题了)
  8. C看到了动态2,发现误会了

画成图,大致如下:

所有的因果关系罗列一下(不考虑8):

A的因果关系:W1 -> W2

B的因果关系:R1 -> R2 -> W6

C的因果关系:

A和B之间的因果关系有:W2 -> R2, W1 -> R1

B和C之间的因果关系有:W6 -> R6

A和C之间也有因果关系:W1 -> R1

你会发现,刚到第7步时,虽然因果关系图还是没有产生环的,但是此时因果已经出问题了(产生误会了)

W1
R1
R2
W6
R6
W2

所以为了保证因果一致性,必须:当我看到别人的果时,我必须要看到该果之前的所有因;而不是傻傻地检测新的事件会不会造成环

在这里插入图片描述

最终一致性

最终总能到达一个完全一致的阶段,大家手里的数据都是一样的

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

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

相关文章

【异常报错】must call Vue.use(Vuex)

这个错误应该是在创建Vuex中出现的 把你main.js中的Vue.use(Vuex)写到store中,这里我的store/index.js中,即完美解决 其实仔细想想也可以发现,import就把整个文件给引入了,而index.js中有创建Store的实例,而在这时我们还没有Vue.…

Redis集群架构搭建——主从、哨兵、集群

上一篇文章Ubuntu上通过源码方式安装Redis已经介绍了如何安装redis,在这篇文章中,将会教大家搭建Redis的几种高可用的架构:主从架构、哨兵集群、Cluster集群。 本篇文章使用的redis版本为6.2.13,不同版本的配置可能有略微的区别&a…

腾讯云微服务平台 TSF 异地多活单元化能力重磅升级

导语 2023腾讯全球数字生态大会已于9月7-8日完美落幕,40专场活动展示了腾讯最新的前沿技术、核心产品、解决方案。 微服务与消息队列专场,腾讯云微服务平台 TSF 产品经理张桢带来了《腾讯云微服务平台 TSF 异地多活单元化能力重磅升级》的精彩演讲。本…

Centos7部署单机版MongoDB

目录 Centos7部署单机版MongoDBMongoDB介绍数据模型索引分布式高可用性查询语言驱动和社区用途缺点 下载并解压安装包创建相关文件夹和文件编辑mongod.conf文件启动mongodb创建管理员用户终止MongoDB服务配置自启动服务关闭SELinux编辑自启动服务文件mongodb服务命令 Centos7部…

iOS17.0.2更新修复iPhone 15系列机型数据迁移问题,附新机快速数据迁移办法!

iPhone 15 系列机型已于今日正式发售,为解决iPhone15这些机型出现的数据迁移问题,苹果紧急发布了 iOS 17.0.2 更新,内部版本号为 21A350。 需要注意的是, iOS 17.0.2 更新仅适用于 iPhone 15、iPhone 15 Plus、iPhone 15 Pro 和 …

QT-day2

完善登录框 点击登录按钮后,判断账号(admin)和密码(123456)是否一致,如果匹配失败,则弹出错误对话框,文本内容“账号密码不匹配,是否重新登录”,给定两个按钮…

Android 启动优化案例:WebView非预期初始化排查

去年年底做启动优化时,有个比较好玩的 case 给大家分享下,希望大家能从我的分享里 get 到我在做一些问题排查修复时是怎么看上去又low又土又高效的。 1. 现象 在我们使用 Perfetto 进行app 启动过程性能观测时,在 UI 线程发现了一段 几十毫…

ruoyi框架修改左侧菜单样式

菜单效果 ruoyi前端框架左侧的菜单很丑,我们需要修改一下样式,下面直接看效果。 修改代码 1、sidebar.scss .el-menu-item, .el-submenu__title {overflow: hidden !important;text-overflow: ellipsis !important;white-space: nowrap !important;//…

Docker核心原理与实操

第一章、Docker基本概念 1、概念:Docker是一种容器技术,可以解决软件跨环境迁移问题。 2、实现原理:是一个分层复用的文件系统;每一层都是一个独立的软件; …

Linux中创建用户要自己设置密码

因为不知道Linux默认设置的密码,没办法接下来愉快的使用。如下: 而想要新建Linux用户密码,请您执行以下步骤: . 1.打开终端并以root身份登录; 2.输入命令“useradd username",其中username为您新建的用户名; 3.使用命令“passwd usernam…

SDXL prompt 笔记

模型 模型有两个,分别是 stable-diffusion-xl-base-1.0、stable-diffusion-xl-refiner-1.0。 base 模型是用来做文生图,refiner 模型是用来做图生图的。 SDXL 模型之 base、refiner 和 VAE_云水木石的博客-CSDN博客 分辨率 默认是1024*1024&#xf…

Springboot2 Pandas Pyecharts 量子科技专利课程设计大作业

数据集介绍 1.背景 根据《中国科学:信息科学》期刊上的一篇文章,量子通信包括多种协议与应用类型: 基于量子隐形传态与量子存储中继等技术,可实现量子态信息传输,进而构建量子信息网络,已成为当前科研热点&…

GDB的TUI模式(文本界面)

2023年9月22日,周五晚上 今晚在看GDB的官方文档时,发现GDB居然有文本界面模式 TUI (Debugging with GDB) (sourceware.org) GDB开启TUI的条件 GDB的文本界面的开启条件是:操作系统有适当版本的curses库 The TUI mode is supported only on…

ArrayList 的自动扩容机制

触发扩容 ArrayList 是一个数组结构的存储容器,默认情况下,数组的长度是 10 当然我们也可以在构建 ArrayList 对象的时候自己指定初始长度。随着在程序里面不断的往 ArrayList 中添加数据,当添加的数据达到 10 个的时候,ArrayLis…

web:[GXYCTF2019]Ping Ping Ping

题目 点进题目,页面只显示/?ip,没有其他信息 联系到题目名为ping,猜测题目于ping地址有关,先尝试一下 构造payload http://31e941af-c0d7-49c9-a3fe-84cb13d8adae.node4.buuoj.cn:81/?ip127.0.0.1 这里猜测可能为远程命令执行…

Linux(CentOS)安装msf

目录 一、安装MSF 1.1 在线安装 1.2 离线安装 二、安装Postgresql数据库 一、安装MSF 1.1 在线安装 需要挂梯子!挂完梯子需要reboot重启,多试几次就可以,国内网络我试了很久都不行。没条件没梯子的看1.2离线安装 cd /opt curl https://ra…

Cortex-M4之FPU单元

最近在学习实时操作系统,以下是我对学习实时操作系统过程中做的一些笔记。 一、FPU单元 在 Coretex-M4 处理器中有一个可选的单精度 FPU 单元,一般 STM32F429 就有 FPU 单元, 如果使能了 FPU 单元的话就可以使用它来对单精度浮点数进行计算…

【探索Linux世界|中秋特辑】--- 倒计时和进度条的实现与演示

个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【Linux专栏】🎈 本专栏旨在分享学习Linux的一点学习心得,欢迎大家在评论区讨论💌 演示环境&#xff1…

栈的详细实现

一 定义 概念 栈是一种特殊的线性表,只允许在固定的一端进行操作。该端叫做栈顶,相对的另一端叫做栈底。 符合LIFO(后进先出)的规则 关于栈顶的两个操作: 压栈/入栈/进栈:在栈顶部插入数据 出栈:栈顶删…

2023华为杯研究生数学建模C题分析

完整的分析查看文末名片获取! 问题一 在每个评审阶段,作品通常都是随机分发的,每份作品需要多位评委独立评审。为了增加不同评审专家所给成绩之间的可比性,不同专家评审的作品集合之间应有一些交集。但有的交集大了,则…