”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 了解无冲突复制数据类型

了解无冲突复制数据类型

发布于2024-11-07
浏览:694

无冲突复制数据类型 (CRDT) 是一类数据结构,可在分布式系统中实现无缝协作和数据同步,从而实现无冲突的协作更新。 CRDT 旨在实现跨多个数据副本的最终一致性,确保即使更新独立发生,所有副本也能收敛到相同状态,而不需要复杂的冲突解决机制。

在这篇博文中,我们将深入研究 CRDT 是什么,探索它们的用途和类型,了解它们的工作原理,并学习如何实现它们,重点关注 JavaScript 和强大的 Yjs 库。

CRDT 的用例

CRDT 在实时协作和离线支持至关重要的场景中特别有用:

  1. 协作文本编辑器:Google Docs、Notion 和 Etherpad 使用类似 CRDT 的结构进行实时编辑。
  2. 协作设计工具:Figma 是一种流行的基于 Web 的设计工具,它使用 CRDT 来实现设计项目的实时协作。多个设计人员可以同时处理同一个文件,所有用户之间的更改可以无缝同步。
  3. 分布式数据库:RxDB 和 Riak 使用 CRDT 进行无冲突复制。
  4. 多人游戏:用于保持玩家之间一致的游戏状态。

CRDT 的类型

CRDT 主要有两种类型:

  1. 基于状态的 CRDT:它们复制数据结构的整个状态。合并是通过比较和协调不同副本的状态来完成的。
  2. 基于操作的 CRDT:它们复制对数据结构执行的操作。合并是通过以交换方式应用来自不同副本的操作来完成的。

CRDT 的工作原理

CRDT(无冲突复制数据类型)的运行原理可确保所有数据副本的最终一致性,即使是同时进行更新或发生网络分区时也是如此。让我们更深入地研究一下机制:

主要特性

  1. 交换性:该属性确保运算顺序不会影响最终结果。例如,在计数器 CRDT 中,先递增 2,然后再递增 3,与先递增 3,然后再递增 2 产生的结果相同。
  2. 关联性:这意味着操作的分组并不重要。再次使用计数器示例,(1 2) 3 与 1 (2 3) 相同。
  3. 幂等性:多次应用相同的操作与应用一次效果相同。这对于处理分布式系统中的重复消息至关重要。

冲突解决

CRDT 通过设计自动解决冲突:

  • 对于基于状态的 CRDT (CvRDT),这是通过组合两个副本的状态的合并函数来实现的。此合并函数必须是可交换的、关联的和幂等的。
  • 对于基于操作的 CRDT (CmRDT),操作被设计为可交换的,确保以任何顺序应用它们都会导致相同的最终状态。

逻辑时钟

许多 CRDT 实现使用逻辑时钟(例如版本向量或点分版本向量)来跟踪操作的因果历史。这有助于确定并发操作的顺序以及确定副本已经看到哪些更新。

在 JavaScript 中使用 CRDT 和 Yjs

从头开始实施 CRDT 可能很复杂。但是,有一些库可以简化该过程。对于 JavaScript,最流行的 CRDT 库之一是 Yjs。它是一个高性能的CRDT实现,支持各种数据类型。让我们使用 Yjs 创建一个简单的待办事项列表应用程序,模拟多个用户处理内存中的同一文档。

下面是如何使用 Yjs 实现共享待办事项列表的示例:
Understanding Conflict-Free Replicated Data Types

让我们使用创建的 ydocs :
Understanding Conflict-Free Replicated Data Types

在此示例中,我们创建两个 Yjs 文档(ydoc1 和 ydoc2)来模拟两个用户处理同一待办事项列表。每个文档都有自己的待办事项共享地图。

我们定义了添加、更新和删除待办事项的函数,以及用于手动同步两个文档之间的状态的syncDocs函数。这模拟了在客户端之间交换更新的网络环境中会发生的情况。

结论

CRDT 为构建可在线和离线无缝工作的协作分布式应用程序提供了强大的解决方案。虽然底层概念可能很复杂,但像 Yjs 这样的库使开发人员可以更轻松地在其应用程序中利用 CRDT 的强大功能。随着分布式系统变得越来越普遍,理解和利用 CRDT 将成为开发人员越来越有价值的技能。

有用的链接

  1. Yjs
  2. CRDT
  3. Tiptap - 协作文本编辑器
版本声明 本文转载于:https://dev.to/adityasajoo/understanding-conflict-free-replicated-data-types-57jc?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何有效地转换PHP中的时区?
    如何有效地转换PHP中的时区?
    在PHP 利用dateTime对象和functions DateTime对象及其相应的功能别名为时区转换提供方便的方法。例如: //定义用户的时区 date_default_timezone_set('欧洲/伦敦'); //创建DateTime对象 $ dateTime = ne...
    编程 发布于2025-05-22
  • 在程序退出之前,我需要在C ++中明确删除堆的堆分配吗?
    在程序退出之前,我需要在C ++中明确删除堆的堆分配吗?
    在C中的显式删除 在C中的动态内存分配时,开发人员通常会想知道是否有必要在heap-procal extrable exit exit上进行手动调用“ delete”操作员,但开发人员通常会想知道是否需要手动调用“ delete”操作员。本文深入研究了这个主题。 在C主函数中,使用了动态分配变量(H...
    编程 发布于2025-05-22
  • 如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    在Visual Studio 2012 尽管已安装了MySQL Connector v.6.5.4,但无法将MySQL数据库添加到实体框架的“ DataSource对话框”中。为了解决这一问题,至关重要的是要了解MySQL连接器v.6.5.5及以后的6.6.x版本将提供MySQL的官方Visual...
    编程 发布于2025-05-22
  • 如何在Chrome中居中选择框文本?
    如何在Chrome中居中选择框文本?
    选择框的文本对齐:局部chrome-inly-ly-ly-lyly solument 您可能希望将文本中心集中在选择框中,以获取优化的原因或提高可访问性。但是,在CSS中的选择元素中手动添加一个文本 - 对属性可能无法正常工作。初始尝试 state)</option> < op...
    编程 发布于2025-05-22
  • 在Oracle SQL中如何提取下划线前的子字符串?
    在Oracle SQL中如何提取下划线前的子字符串?
    [ 在oracle sql 解决方案: Explanation:SUBSTR function extracts a substring starting from the specified position (0) and continuing for a specified length.IN...
    编程 发布于2025-05-22
  • 解决Spring Security 4.1及以上版本CORS问题指南
    解决Spring Security 4.1及以上版本CORS问题指南
    弹簧安全性cors filter:故障排除常见问题 在将Spring Security集成到现有项目中时,您可能会遇到与CORS相关的错误,如果像“访问Control-allo-allow-Origin”之类的标头,则无法设置在响应中。为了解决此问题,您可以实现自定义过滤器,例如代码段中的MyFi...
    编程 发布于2025-05-22
  • 使用jQuery如何有效修改":after"伪元素的CSS属性?
    使用jQuery如何有效修改":after"伪元素的CSS属性?
    在jquery中了解伪元素的限制:访问“ selector 尝试修改“:”选择器的CSS属性时,您可能会遇到困难。 This is because pseudo-elements are not part of the DOM (Document Object Model) and are th...
    编程 发布于2025-05-22
  • 为什么PYTZ最初显示出意外的时区偏移?
    为什么PYTZ最初显示出意外的时区偏移?
    与pytz 最初从pytz获得特定的偏移。例如,亚洲/hong_kong最初显示一个七个小时37分钟的偏移: 差异源利用本地化将时区分配给日期,使用了适当的时区名称和偏移量。但是,直接使用DateTime构造器分配时区不允许进行正确的调整。 example pytz.timezone(...
    编程 发布于2025-05-22
  • 找到最大计数时,如何解决mySQL中的“组函数\”错误的“无效使用”?
    找到最大计数时,如何解决mySQL中的“组函数\”错误的“无效使用”?
    如何在mySQL中使用mySql 检索最大计数,您可能会遇到一个问题,您可能会在尝试使用以下命令:理解错误正确找到由名称列分组的值的最大计数,请使用以下修改后的查询: 计数(*)为c 来自EMP1 按名称组 c desc订购 限制1 查询说明 select语句提取名称列和每个名称...
    编程 发布于2025-05-22
  • 如何限制动态大小的父元素中元素的滚动范围?
    如何限制动态大小的父元素中元素的滚动范围?
    在交互式接口中实现垂直滚动元素的CSS高度限制问题:考虑一个布局,其中我们具有与用户垂直滚动一起移动的可滚动地图div,同时与固定的固定sidebar保持一致。但是,地图的滚动无限期扩展,超过了视口的高度,阻止用户访问页面页脚。$("#map").css({ marginT...
    编程 发布于2025-05-22
  • Android如何向PHP服务器发送POST数据?
    Android如何向PHP服务器发送POST数据?
    在android apache httpclient(已弃用) httpclient httpclient = new defaulthttpclient(); httppost httppost = new httppost(“ http://www.yoursite.com/script.p...
    编程 发布于2025-05-22
  • 如何使用Java.net.urlConnection和Multipart/form-data编码使用其他参数上传文件?
    如何使用Java.net.urlConnection和Multipart/form-data编码使用其他参数上传文件?
    使用http request 上传文件上传到http server,同时也提交其他参数,java.net.net.urlconnection and Multipart/form-data Encoding是普遍的。 Here's a breakdown of the process:Mu...
    编程 发布于2025-05-22
  • Java数组中元素位置查找技巧
    Java数组中元素位置查找技巧
    在Java数组中检索元素的位置 利用Java的反射API将数组转换为列表中,允许您使用indexof方法。 (primitives)(链接到Mishax的解决方案) 用于排序阵列的数组此方法此方法返回元素的索引,如果发现了元素的索引,或一个负值,指示应放置元素的插入点。
    编程 发布于2025-05-22
  • 您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    在javascript console 中显示颜色是可以使用chrome的控制台显示彩色文本,例如红色的redors,for for for for错误消息?回答是的,可以使用CSS将颜色添加到Chrome和Firefox中的控制台显示的消息(版本31或更高版本)中。要实现这一目标,请使用以下模...
    编程 发布于2025-05-22

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3