SOFAJRaft 基于 RAFT 一致性算法的 Java 实现 项目简介
SOFAJRaft 是一个基于 RAFT 一致性算法的生产级高性能 Java 实现,支持 MULTI-RAFT-GROUP,适用于高负载低延迟的场景。 使用 SOFAJRaft 你可以专注于自己的业务领域,由 SOFAJRaft 负责处理所有与 RAFT 相关的技术难题,并且 SOFAJRaft 非常易于使用,你可以通过几个示例在很短的时间内掌握它。功能特性Leader 选举 日志复制和恢复 快照和日志压缩 集群线上配置变更,增加节点、删除节点、替换节点等 主动变更 Leader,用于重启维护,Leader 负载平衡等 对称网络分区容忍性 非对称网络分区容忍性 容错性,少数派故障,不影响系统整体可用性 多数派故障时手动恢复集群可用 高效的线性一致读,ReadIndex/LeaseRead 流水线复制 内置了基于 Metrics 类库的性能指标统计,有丰富的性能统计指标 通过了 Jepsen 一致性验证测试 JRaft 中包含了一个嵌入式的分布式 KV 实现致谢SOFAJRaft 是从百度的 braft 移植而来,做了一些优化和改进,感谢百度 braft 团队开源了如此优秀的 C++ RAFT 实现开源许可SOFAJRaft 基于 Apache License 2.0 协议,SOFAJRaft 依赖了一些第三方组件,它们的开源协议也为 Apache License 2.0, 另外 SOFAJRaft 也直接引用了一些开源协议为 Apache License 2.0 的代码(可能有一些小小的改动)包括:JCTools 中的 NonBlockingHashMap/NonBlockingHashMapLong Netty 中的 HashedWheelTimer,另外还参考了 Netty 的 Pipeline 设计 Protobuf 中对 UTF8 String 高效的编码/解码