Apache ServiceComb Pack 是一个微服务应用的数据最终一致性解决方案。
特性
- 高可用。支持集群模式。
- 高可靠。所有的事务事件都持久存储在数据库中。
- 高性能。事务事件是通过gRPC来上报的,且事务的请求信息是通过Kyro进行序列化和反序列化的。
- 低侵入。仅需2-3个注解和编写对应的补偿方法即可进行分布式事务。
- 部署简单。可通过Docker快速部署。
- 支持前向恢复(重试)及后向恢复(补偿)。
- 扩展简单。基于Pack架构很容实现多种协调协议,目前支持TCC,Saga协议。
架构
ServiceComb Pack 架构是由 alpha 和 omega组成,其中:
- alpha充当协调者的角色,主要负责对事务进行管理和协调。
- omega是微服务中内嵌的一个agent,负责对网络请求进行拦截并向alpha上报事务事件。
下图展示了alpha, omega以及微服务三者的关系: 在此架构基础中我们除了实现saga协调协议以外,我们还可以很容易实现TCC协调协议。 详情可浏览ServiceComb Pack 设计文档.
同时社区也提供了多种语言的Omega实现:
快速入门
编译和运行代码
- 编译代码并且运行相关的单元测试
$ mvn clean install
- 编译示例,并生产docker镜像,运行验收测试
$ mvn clean install -Pdemo,docker
- 编译示例,并生产docker镜像, 不运行测试
$ mvn clean install -DskipTests=true -Pdemo,docker
- 当前ServiceComb Pack同时支持Spring Boot 1.x 以及 Spring Boot 2.x, 在缺省情况下ServiceComb Pack会使用Spring Boot 1.x来进行构建。 你可以使用 -Pspring-boot-2 将Spring Boot版本转换到 2.x 上。 由于Spring Boot 只在2.x开始支持 JDK9,如果你想用 JDK9或者JDK10 来编译Saga并运行测试的话,你需要使用 spring-boot-2 profile参数。
$ mvn clean install -Pdemo,docker,spring-boot-2
用户指南
如何构建和使用可浏览用户指南。
获取最新发行版本
下载Pack
联系我们
贡献
详情可浏览代码提交指南。
License
Apache 2.0 license。