《Windows Azure Platform 系列文章目录

  我个人感觉,这个概念和分布式系统中的CAP原则是类似的:

  CAP原则指的是在一个分布式系统中,Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可得兼

  Azure CosmosDB有五种一致性级别,从数据一致性角度来说,我们按照最强的一致性,到最低的一致性,排序如下:

  1.Strong (强一致性)

  2.Bounded Staleness

  3.Session (会话一致性)

  4.Consistent prefix (一致性前缀)

  5.最终一致性 (Eventual Consistency)

  每一种级别都在一致性(Consistency)可用性(Availability)和性能(Performance)之间进行了权衡,并且有SLA (Service Level Agreement)

  一致性级别和延迟

  对所有一致性级别的读操作延迟,在第99位百分位的延迟小于10毫秒。该读操作的延迟是有SLA保障的。

  The read latency for all consistency levels is always guaranteed to be less than 10 milliseconds at the 99th percentile. This read latency is backed by the SLA.

  平均的读延迟,在第50个百分位的延迟小于2毫秒。The average read latency, at the 50th percentile, is typically 2 milliseconds or less

  跨多个Azure区域且配置了Strong (强一致性)的CosmosDB账户,不在上面的性能指标范围内。

  对所有一致性级别的写操作,在第99位百分位的延迟小于10毫秒。该写操作的延迟也是有SLA保障的。

  The write latency for all consistency levels is always guaranteed to be less than 10 milliseconds at the 99th percentile. This write latency is backed by the SLA.

  平均的写操作,在第50个百分位的延迟小于5毫秒

  当Azure CosmosDB账户跨一个Azure数据中心区域,且配置了强一致性(Strong)的场景情况下,

  写入延迟保证小于两个最远Azure区域中任何一个之间的往返时间(RTT)的两倍,加上第99百分位数的10毫秒。

  这里举个例子,假设我们创建了Azure CosmosDB账户,且跨越了:Azure 新加坡数据中心、Azure香港数据中心和Azure东京数据中心,配置了强(Strong)一致性的场景。

  写入的延迟=区域中任何一个之间的往返时间(round-trip time,RTT)的两倍=Azure新加坡数据中心<--->Azure东京数据中心之间的往返时间(RTT)的两倍,再加上第99百分位数的10毫秒

  因为在分布式系统中,针对于强一致性(Strong)写入的场景,需要在所有分布式节点都执行了写入操作后,才会被确定返执行成功。

  此选项目前处于预览状态

  准确的往返时间(round-trip time, RTT)取决于光的速度和Azure网络拓扑结构。 Azure 网络不会针对任意两个 Azure 区域之间的 RTT 提供任何延迟 SLA。

  对于你的 Azure Cosmos 帐户,将在 Azure 门户中显示复制延迟。 可以使用 Azure 门户监视与你的帐户关联的各个区域之间的复制延迟

  一致性级别和吞吐量

  在相同Request Unit (是CosmosDB的性能指标,我们会在后面的章节做详细的介绍)情况下,Session (会话一致性),Consistent prefix (一致性前缀)和最终一致性 (Eventual Consistency)的读取操作的吞吐量,是Strong (强一致性)和Bounded Staleness的两倍

  对于给定类型的写入操作(例如插入、替换、更新插入和删除),所有一致性级别在相同的Request Unit情况下,写入吞吐量是相同的

  

  一致性界别和数据持久化

  在Azure多区域分布式数据库环境中,当发生区域范围的服务中断时,一致性级别与数据持续性之间存在直接关系。 制定业务连续性计划时,需了解应用程序在中断事件发生后完全恢复之前的最大可接受时间。 应用程序完全恢复所需的时间称为恢复时间目标 (RTO)。 此外,还需要了解从中断事件恢复时,应用程序可忍受最近数据更新丢失的最长期限。 可以承受更新丢失的时限称为恢复点目标 (RPO)。

  下表定义了当发生区域范围的服务中断时,一致性模型与数据持续性之间的关系。 请务必注意,在分布式系统中,由于 CAP 定理的存在,即使一致性较高,也不可能存在 RPO 和 RTO 为零的分布式数据库

Azure区域 复制模式 一致性级别 RPO RTO
1

单主或多主

Single or Multi-Master

任何一致性级别 <240分钟 <1周
>1

单主

Single Master

Session (会话一致性)

Consistent prefix (一致性前缀)

最终一致性 (Eventual Consistency)

<15分钟 <15分钟
>1

单主

Single Master

Bounded Staleness K&T <15分钟
>1

多主

Multi-Master

Session (会话一致性)

Consistent prefix (一致性前缀)

最终一致性 (Eventual Consistency)

<15分钟 0
>1

多主

Multi-Master

Bounded Staleness K&T 0
>1

单主或多主

Single or Multi-Master

Strong (强一致性) 0 <15分钟

  K = 某个项的“K”版本(更新)的数目。

  T =时间“T”,自上次更新以来的时间间隔。

Azure CosmosDB (4) 在一致性(Consistency)可用性(Availability)和性能(Performance)之间的权衡的更多相关文章

  1. 分布式CAP理论介绍:一致性(Consistency),可用性(Availability),容忍网络分区(Partition tolerance)

    在理论计算机科学中,CAP定理(CAP theorem),又被称作布鲁尔定理(Brewer's theorem),它指出对于一个分布式计算系统来说,不可能同时满足以下三点: 一致性(Consisten ...

  2. Azure CosmosDB (3) 选择适当的一致性级别

    <Windows Azure Platform 系列文章目录> 绝大部分的商业分布式数据库,要求开发人员选择两个极端的数据库一致性:强一致性(Strong Consistency)和最终一 ...

  3. Azure CosmosDB (2) CosmosDB中的数据一致性

    <Windows Azure Platform 系列文章目录> 为了保证分布式数据库的高可用性和低延迟性,我们需要在可用性.延迟和吞吐量之间进行权衡. 绝大部分的商业分布式数据库,要求开发 ...

  4. 详解 CAP 定理 Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性)

    CAP原则又称CAP定理,指的是在一个分布式系统中,Consistency(一致性). Availability(可用性).Partition tolerance(分区容错性),三者不可得兼. 分布式 ...

  5. 数据一致性(consistency)、服务可用性(availability)、分区容错性(partition-tolerance)

    数据一致性(consistency).服务可用性(availability).分区容错性(partition-tolerance) 分布式系统理论基础 - CAP 2016-04-04 18:27 b ...

  6. CAP理论与MongoDB一致性、可用性的一些思考

    大约在五六年前,第一次接触到了当时已经是hot topic的NoSql.不过那个时候学的用的都是mysql,Nosql对于我而言还是新事物,并没有真正使用,只是不明觉厉.但是印象深刻的是这么一张图片( ...

  7. Azure CosmosDB (1) 概述

    <Windows Azure Platform 系列文章目录> Azure CosmosDB是一个全球分布式数据库服务(Global Distributed Database),提供低延迟 ...

  8. Azure CosmosDB (8) 性能指标Request Unit-RU

    <Windows Azure Platform 系列文章目录> 本次将介绍Cosmos DB的性能指标RU (Request Unit). 总的来说,我们设置的Azure CosmosDB ...

  9. Azure 中虚拟机的区域和可用性

    Azure 在中国的两个数据中心运行. 这些数据中心分组到地理区域,让用户可灵活选择构建应用程序的位置. 请务必了解 Azure 中虚拟机 (VM) 运行的方式和位置,以及最大化性能.可用性和冗余的选 ...

随机推荐

  1. 【转】Android-Input 触控笔

    https://source.android.com/devices/accessories/stylus 触控笔 Android 6.0 及更高版本支持蓝牙 (BT).蓝牙低功耗 (BTLE) 或 ...

  2. SHELL输出带颜色字体

    输出特效格式控制:\033[0m  关闭所有属性  \033[1m   设置高亮度  \03[4m   下划线  \033[5m   闪烁  \033[7m   反显  \033[8m   消隐  \ ...

  3. 关于freemarker 空变量的接收以及类型转换 笔记

    通常接收一个变量是${siOrganid},如果并没有这个变量,是这么处理${siOrganid!},如果这个变量是某个类属性,是这么处理${interfsrv.siOrganid!},如果这个类也是 ...

  4. PHP为什么有人学不会

    互联网进入到人们生活中的方方面面了,世界首富比尔盖茨多次提到青少年编程,而编程是一种思维习惯的转化. 作为写了10几年程序的人,我听到过一些说编程不好学的抱怨. 从目前见到的数据统计,主要是因为在大学 ...

  5. jQuery-4.动画篇---上卷下拉效果

    jQuery中下拉动画slideDown 对于隐藏的元素,在将其显示出来的过程中,可以对其进行一些变化的动画效果.之前学过了show方法,show方法在显示的过程中也可以有动画,但是.show()方法 ...

  6. Hive与HBase表联合使用Join的问题

    hive与hbase表结合级联查询的问题,主要hive两个表以上涉及到join操作,就会长时间卡住,查询日志也不报错,也不会出现mr的进度百分比显示,shell显示如下图 如图: 解决这个问题,需要修 ...

  7. 自定义EL函数(以将字母转为大写为例)

    Step1 定义一个类:StringFunction.java 主要作用是来提供转大写的方法; public class StringFunction { public static String t ...

  8. s21day19 python笔记

    s21day19 python笔记 一.面向对象的基本知识 1.1 基本格式 # 定义类 class 类名: def 方法名(self,name): print(name) return 123 de ...

  9. vue 新建项目

    1. 首先安装node.js,安装时一直点Next,知道Finish就可以安装成功 2. 打开控制命令执行程序cmd,输入node -v ,可以查看node的版本信息,即安装成功,我安装的是v8.12 ...

  10. curl请求

    <?php $cookie_file = tempnam('./temp','cookie');  //创建cookie文件保存的位置/** * [curl description] * @pa ...