大家好,又见面了,我是你们的朋友全栈君。
Hmily 是一款高性能分布式事务 tcc 开源框架。基于java语言来开发(JDK1.8),支持 Dubbo、Spring Cloud、Motan 等 RPC 框架进行分布式事务。
Spring-Boot
, Spring-Namespace
快速与业务系统集成Dubbo
, SpringCloud
,Motan
, Sofa-rpc
, brpc
, tars
等知名RPC框架mysql
, oracle
, mongodb
, redis
, zookeeper
等方式JDK8+
RPC
框架, 比如 : Dubbo
, SpringCloud
,Montan
TCC是一种比较成熟的分布式事务解决方案,可用于解决跨库操作的数据一致性问题; TCC是服务化的两阶段编程模型,其Try,Confirm,Cancel3个方法均由业务编码实现。
业务实现TCC 服务之后,该TCC服务将作为分布式事务的其中一个资源,参与到整个分布 式事务中;事务管理器分2个阶段协调服务,在第一个阶段调用所有TCC服务的Try方法, 在第二阶段执行所有TCC服务的Confirm或者Cancel方法。如果Try执行成功,则执行Confirm 进行确认业务操作;如果Try执行失败,则执行Cancel取消Try阶段预留的业务资源。
TAC
模式其实是TCC
模式的变种,顾名思义 TAC
模式被称为自动回滚,相比于 TCC
模式,用户完全不用关心 回滚方法如何去写,减少了用户的开发量,对用户完全透明。
TAC
模式只适合于关系型数据库。TAC
模式会拦截用户的SQL语句生成反向回滚SQL,SQL的兼容度也会是一大考验。官方文档:https://dromara.org/zh-cn/docs/hmily/config.html
/**
* The annotation Hmily.
*
* @author xiaoyu
*/
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Hmily {
}
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface HmilyTCC {
/**
* Confirm method string.
*
* @return the string
*/
String confirmMethod() default "";
/**
* Cancel method string.
*
* @return the string
*/
String cancelMethod() default "";
/**
* Pattern pattern enum.
*
* @return the pattern enum
*/
TransTypeEnum pattern() default TransTypeEnum.TCC;
}
confirmMethod
: 注解标识方法的,确认方法名称,该方法参数列表与返回类型应与标识方法一致。cancelMethod
: 注解标识方法的,回滚方法名称,该方法参数列表与返回类型应与标识方法一致。/**
* The annotation HmilyTAC.
*
* @author xiaoyu
*/
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface HmilyTAC {
}
步骤一: 引入依赖jar包
步骤二:引入hmily配置
步骤三:在具体的实现方法上(服务提供端),加上HmilyTCC or HmilyTAC 注解
步骤四:在feignClient调用方法上(消费方),加上Hmily
<dependency>
<groupId>org.dromara</groupId>
<artifactId>hmily-springcloud</artifactId>
<version>{last.version}</version>
</dependency>
<!--配置扫码hmily框架的包-->
<context:component-scan base-package="org.dromara.hmily.*"/>
<!--设置开启aspectj-autoproxy-->
<aop:aspectj-autoproxy expose-proxy="true"/>
<!--配置Hmily启动的bean参数-->
<bean id="hmilyApplicationContextAware" class="org.dromara.hmily.spring.HmilyApplicationContextAware"/>
<dependency>
<groupId>org.dromara</groupId>
<artifactId>hmily-spring-boot-starter-springcloud</artifactId>
<version>{last.version}</version>
</dependency>
seata | hmily | 对比 |
---|---|---|
TCC | TCC | 基本相似,都需要自己写回滚或提交方法 |
TAC | XA,AT | 自动回滚,TAC (开发中,未开放);AT无侵入的分布式事务解决方案,适用于不希望对业务进行改造的场景,几乎0学习成本;XA模式是分布式强一致性的解决方案,但性能低而使用较少 |
SAGA | 长事务解决方案,适用于业务流程长且需要保证事务最终一致性的业务系统,Saga 模式一阶段就会提交本地事务,无锁,长流程情况下可以保证性能,多用于渠道层、集成层业务系统。事务参与者可能是其它公司的服务或者是遗留系统的服务,无法进行改造和提供 TCC 要求的接口,也可以使用 Saga 模式; |
注意:本文归作者所有,未经作者允许,不得转载
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/143291.html原文链接:https://javaforall.cn