CRDT宝典 - Multi-Value-Register

宝典目录

背景

学了这么多state-based CRDT,我们发现merge一般都要解决冲突(除了kernel), 我们比较两个对同一个元素的操作,有四种状态

  1. 大于
  2. 小于
  3. 等于
  4. 冲突

当状态为冲突时,我们有一些解决冲突的方式,比如

  1. 基于LLW-Register的last-write-wins策略
  2. 基于GCounter的Add-Wins策略

可是我们业务有一些场景,需要在实际遇到冲突时,才决定使用什么策略来解决冲突,比如权限问题,权限高的用户可以覆盖权限低的用户,权限低的用户不能覆盖权限高的用户。

这就要求我们的CRDT在遇到冲突时,将冲突抛出,由实际的业务代码来决定使用什么策略来解决冲突。

它有一个专业的名字:多值寄存器,Multi Value Registers。

这个MVR在初始化时,需要业务代码里传入解决冲突的算法,然后将其应用在CRDT上。

相关推荐
子兮曰20 小时前
OpenClaw入门:从零开始搭建你的私有化AI助手
前端·架构·github
吴仰晖20 小时前
使用github copliot chat的源码学习之Chromium Compositor
前端
1024小神20 小时前
github发布pages的几种状态记录
前端
心态还需努力呀1 天前
CANN仓库通信库:分布式训练的梯度压缩技术
分布式·cann
那个村的李富贵1 天前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿1 天前
Scaled Dot-Product Attention 分数计算 C++
算法
不像程序员的程序媛1 天前
Nginx日志切分
服务器·前端·nginx
北原_春希1 天前
如何在Vue3项目中引入并使用Echarts图表
前端·javascript·echarts
尽意啊1 天前
echarts树图动态添加子节点
前端·javascript·echarts
吃面必吃蒜1 天前
echarts 极坐标柱状图 如何定义柱子颜色
前端·javascript·echarts