SOFAJRaft v1.2.5 发布了,本期发布内容
-
Bug 修复
- 修复 rheakv rocksdb 存储实现在启动时没有删除数据的问题,会导致非幂等操作出现不一致,比如 getSequence 跳跃
-
新功能
-
优化了 multi-raft-group 的 snapshot #42
-
Breaking Changes
SOFAJRaft 简介
SOFAJRaft 是一个基于 RAFT
一致性算法的生产级高性能 Java 实现,支持 MULTI-RAFT-GROUP,适用于高负载低延迟的场景。 使用 SOFAJRaft 你可以专注于自己的业务领域,由 SOFAJRaft 负责处理所有与 RAFT 相关的技术难题,并且 SOFAJRaft 非常易于使用,你可以通过几个示例在很短的时间内掌握它。
功能特性
- Leader 选举
- 日志复制和恢复
- 快照和日志压缩
- 集群线上配置变更,增加节点、删除节点、替换节点等
- 主动变更 Leader,用于重启维护,Leader 负载平衡等
- 对称网络分区容忍性
- 非对称网络分区容忍性
- 容错性,少数派故障,不影响系统整体可用性
- 多数派故障时手动恢复集群可用
- 高效的线性一致读,ReadIndex/LeaseRead
- 流水线复制
-
内置了基于 Metrics
类库的性能指标统计,有丰富的性能统计指标
-
通过了 Jepsen
一致性验证测试
- JRaft 中包含了一个嵌入式的分布式 KV 实现
原文
https://www.oschina.net/news/106185/sofajraft-1-2-5-released