【分布式事务】GitHub上分布式事务框架压测性能对比

本文对比了hmily和Bytetcc两种分布式事务框架的性能,通过压测实验,分析了各自在高并发场景下的吞吐量、响应时间和数据一致性表现。

一、前言

      随着项目逐步以微服务开发为趋势,逐渐呈现一个服务对应一个数据库。从中产生了分布式事务的问题:一个操作先后调用不同的服务,要保证服务间的事务一致性,这就是分布式事务解决的问题。

      本次调研,根据github上star排名进行调研,主要调研了hmily和bytetcc两种分布式事务框架。

二、选型原则

      本次调研主要是根据CAP和BASE理论进行,主要要保证数据的可用性、分区容错性、最终一致性。

三、调研框架介绍

hmily介绍

      Hmily是由碧桂园工程师开发,高性能异步分布式事务TCC框架。

      Github地址:https://github.com/yu199195/hmily

特点:
1、 采用disruptor框架进行事务日志的异步读写,与RPC框架的性能毫无差别。
2、 RPC框架支持 : dubbo,motan,springcloud。
3、 支持嵌套事务(Nested transaction support).
4、 采用disruptor框架进行事务日志的异步读写,与RPC框架的性能毫无差别。
5、 支持SpringBoot-starter 项目启动,使用简单。
6、 本地事务存储支持 : redis,mongodb,zookeeper,file,mysql。
7、 事务日志序列化支持 :java,hessian,kryo,protostuff。
8、 采用Aspect AOP 切面思想与Spring无缝集成,天然支持集群。
9、 内置经典的分布式事务场景demo工程,并有swagger-ui可视化界面可以快速体验。
10、 异步confirm 和 cancel,保证数据一致性
11、 使用Guava Cache

Bytetcc介绍

      Bytetcc是由北京新奥集团工程师开发,是一个兼容JTA规范的基于TCC机制的分布式事务管理器。目前开发到了第五版,稳定版本为第四版,本次调研为第四版(0.4.x)。

      GitHub地址:https://github.com/liuyangming/ByteTCC

特点:
1、支持Spring容器的声明式事务管理;
2、支持普通事务、TCC事务、saga事务等事务机制;
3、支持多数据源、跨应用、跨服务器等分布式事务场景;
4、支持长事务;
5、支持dubbo服务框架;
6、支持spring cloud;

四、压测机器情况说明

压测机

  • Windows 10 企业版
  • 16GB
  • Jmeter

服务器

服务器cpu服务器内存服务器网络压测机cpu服务器cpu配置服务器内存配置rds的cpu情况,可能多个redis的cpu情况,可能多个
416公司内网44核4G4没有使用

五、压测报告

在这里插入图片描述

在这里插入图片描述

hmily压测报告

正常执行
接口总数平均响应时间中间数90%95%99%最小响应时间最大响应时间错误率吞吐量每秒接受消息每秒发送发送消息线程数
Pay5000002252153473945131313740438.751.4187.82100

      测试结果分析:测试结果发现,吞吐量比较高,但是hmily存在优化的地方,当前版本异步执行confirm和cancel的速度比较慢,且在高并发情况下存在数据不一致问题:

      例如:
      一共执行10w条数据,目标结果:库存-10w , 账户-10w。但是最终执行结果:库存和账户的剩余量不一样。不能保证数据的最终一致性。

      Cpu:
在这里插入图片描述

      DB cpu:
在这里插入图片描述

带回滚操作执行
接口总数平均响应时间中间数90%95%99%最小响应时间最大响应时间错误率吞吐量每秒接受消息每秒发送发送消息线程数
Pay200000157313842703324658154811596062.232.0212.45100

      Cpu:
在这里插入图片描述

      DB cpu:
在这里插入图片描述

Bytetcc 压测报告

正常执行
接口总数平均响应时间中间数90%95%99%最小响应时间最大响应时间错误率吞吐量每秒接受消息每秒发送发送消息线程数
Pay500000119711801534165219008529530106.914.4316.71100

      测试结果分析:吞吐量比较低,可以保证数据的最终一致性。比较稳定。

      Cpu:
在这里插入图片描述

DB cpu:
在这里插入图片描述

带回滚操作执行
接口总数平均响应时间中间数90%95%99%最小响应时间最大响应时间错误率吞吐量每秒接受消息每秒发送发送消息线程数
Pay6000040063556449149732197210010012048.69.19.64100

      Cpu:
在这里插入图片描述

      DB cpu:
在这里插入图片描述

六、小结

      小编只是通过Jmeter对两个比较火的分布式事务框架进行了压测,其中的业务逻辑是一样的,性能也是有不同的。

      测试的代码地址:

      hmily:https://github.com/AresKingCarry/hmilyDemo
      Bytetcc:https://github.com/AresKingCarry/ByteTccDemo

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你个佬六

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值