网站首页 > 开源技术 正文
本次发布增强了Saga在spring下的支持,使用kafka提供重试以及重试失败后放入丢弃队列里
Saga是用来在微服务中的长事务管理,具备ACID中的ACD,不具备I,隔离性。在一定业务条件下,可以使用Saga非常简单和方便的管理微服务事务。同理,也可以用于管理多库事务
Saga要求微服务提供回滚操作,然后如果需要回滚,有Saga编排调度各个微服务对应的回滚服务。BeetlSQL提供了SagaMapper,内置的操作都有对应的回滚操作,也提供@SagaSql,用户提供正向SQl,也提供回滚SQL。这样,在多库环境下,BeetlSQL能正确回滚数据而不依赖于数据库提供的事务
maven
<dependency>
<groupId>com.ibeetl</groupId>
<artifactId>beetlsql</artifactId>
<version>3.1.0-RELEASE</version>
</dependency>
<dependency>
<groupId>com.ibeetl</groupId>
<artifactId>sql-saga-springkafa</artifactId>
<version>3.1.0-RELEASE</version>
</dependency>
@Transactional(propagation = Propagation.NEVER)
public boolean normal(){
SagaContext sagaContext = SagaContext.sagaContextFactory.current();
try{
UserInfoInDs1 ds1 = new UserInfoInDs1();
ds1.setId(100);
ds1.setName("ces");
UserInfoInDs2 ds2 = new UserInfoInDs2();
ds2.setId(100);
ds2.setName("abs");
//俩个数据库
userInfoDs1Mapper.insert(ds1);
userInfoDs2Mapper.insert(ds2);
//模拟一个错误
int a = 1/0;
}catch(Exception ex){
sagaContext.rollback();
return false;
}
return true;
}
需要配置重试队列和丢弃队列名字,以及重试次数,以及kafka序列化方式
beetlsql-saga.kafka.retry-topic=retryTopic002
beetlsql-saga.kafka.fail-topic=failTopic002
spring.kafka.bootstrapServers=127.0.0.1:9092
spring.kafka.consumer.group-id=saga
spring.kafka.consumer.auto-offset-reset=latest
spring.kafka.listener.type=single
spring.kafka.listener.ack-mode=record
spring.kafka.consumer.value-deserializer=org.beetl.sql.saga.kafka.JacksonDeserializer
spring.kafka.producer.value-serializer=org.beetl.sql.saga.kafka.JacksonSerializer
猜你喜欢
- 2024-10-10 软件更新丨Act 1.8.22 发布 - 强大易用的 Java MVC 框架
- 2024-10-10 JKAS开发框架技术文档1:入门(开发框架java)
- 2024-10-10 170823 重温路康桥 这是你心目中的NO.1吗?
- 2024-10-10 Github上不错的开源项目分享(一)(github好的开源项目)
- 2024-10-10 假期归来、多款软件再次发布最新版本
- 2024-10-10 美国发明捡臭臭机器人,识别准确率达94%,铲屎官可能要“失业”
- 2024-10-10 基于Dubbox一个分布式B2C商城(dubbo分布式事务解决方案)
- 2024-10-10 guns-lite 发布了姊妹项目 web-flash,前后端分离的后台管理系统
- 2024-10-10 几款开源的后台管理系统(开源后端)
- 2024-10-10 最美分享 | 码云上GVP级别Star近1W的后台管理系统:RuoYi
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)