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上。

相关推荐
Jinuss30 分钟前
源码分析之React中updateContainerImpl方法更新容器
前端·react.js·前端框架
mjhcsp31 分钟前
透彻背包DP:从DFS暴力搜索到动态规划的逐步推导
算法·深度优先·动态规划
小北方城市网32 分钟前
Redis 分布式锁与缓存三大问题解决方案
spring boot·redis·分布式·后端·缓存·wpf·mybatis
学嵌入式的小杨同学35 分钟前
【嵌入式 C 语言实战】交互式栈管理系统:从功能实现到用户交互全解析
c语言·开发语言·arm开发·数据结构·c++·算法·链表
多米Domi01137 分钟前
0x3f 第40天 setnx的分布式锁和redission,写了一天项目书,光背了会儿八股,回溯(单词搜索)
数据结构·算法·leetcode
乐迪信息38 分钟前
乐迪信息解决港口船型识别难题!AI算法盒子检测船舶类型
人工智能·算法·智能电视
Mr Xu_1 小时前
Vue + Element Plus 实现前端导出 Excel 功能详解
前端·javascript·vue.js
梭七y1 小时前
【力扣hot100题】(151)课程表
算法·leetcode·哈希算法
孞㐑¥1 小时前
算法—滑动窗口
开发语言·c++·经验分享·笔记·算法
仰泳之鹅1 小时前
【杂谈】使用Edge浏览器下载文件显示“Microsoft Defender SmartScreen 已阻止此不安全文件”的解决方法
前端·edge