Seata异常捕获问题之回滚事务如何解决

本文涉及的产品
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
注册配置 MSE Nacos/ZooKeeper,118元/月
性能测试 PTS,5000VUM额度
简介: Seata是一款开源的分布式事务解决方案,旨在提供高效且无缝的分布式事务服务;在集成和使用Seata过程中,开发者可能会遇到不同的异常问题,本合集针对Seata常见异常进行系统整理,为开发者提供详细的问题分析和解决方案,助力高效解决分布式事务中的难题。

问题一:Seata-1.5.2 服务提供方触发全局异常捕获,此时怎么回滚事务?


Seata-1.5.2 服务提供方触发全局异常捕获,此时怎么回滚事务?


参考回答:

认清tm rm的角色定位,要回滚也应该是a去回滚,用api,如果rm发起回滚可能会导致a不知道b已经发起全局事务回滚,a接着调c的情况


关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/481137?spm=5176.21213303.J_qCOwPWspKEuWcmp8qiZNQ.313.6bb82f3dSLrB4q&scm=20140722.S_community@@%E9%97%AE%E7%AD%94@@481137._.ID_481137-RL_seata%E5%BC%82%E5%B8%B8-LOC_search~UND~community~UND~item-OR_ser-V_3-P0_16


问题二:seata 1.5.2并发执行更新同一个数据,各线程回滚,报异常,但是回滚了,是怎么回事啊?


seata 1.5.2并发执行更新同一个数据,各线程回滚,报异常,但是回滚了,是怎么回事啊?java.lang.RuntimeException: org.springframework.dao.QueryTimeoutException: JDBC commit; Global lock wait timeout; nested exception is io.seata.rm.datasource.exec.LockWaitTimeoutException: Global lock wait timeoutCaused by: io.seata.rm.datasource.exec.LockConflictException: get global lock fail, xid:192.168.100.138:8091:2081010340026941329, lockKeys:soho_limit:1610534412086992897,1610534412086992898,1610534412607086594,1610534412607086595


参考回答:

报错就回滚了,重试是在报错之前,看官网参数配置拉下来,faq也有说,获取全局锁失败,一般是出现分布式资源竞争导致,请保证你竞争资源的周期是合理的,并且在业务上做好重试。当一个全局事务因为获取锁失败的时候,应该重新完整地从@Globaltransational的TM端重新发起。 Seata提供了一个“全局锁重试”功能,默认未开启,可以通过下面这个配置来开启。 #遇到全局锁冲突时是否回滚,默认为true client.rm.lock.retryPolicyBranchRollbackOnConflict=false 开启后,默认的全局锁重试逻辑是:线程sleep 10ms,再次争全局锁,最多30次 #你可通过这2个配置来修改锁重试机制 client.rm.lock.retryInterval=10 client.rm.lock.retryTimes=30 另外,你也可以直接在@GlobalTransactional上单独配置重试逻辑,优先级比Seata全局配置更高 @GlobalTransactional(lockRetryInternal = 100, lockRetryTimes = 30) // v1.4.2 @GlobalTransactional(lockRetryInterval = 100, lockRetryTimes = 30) // v1.5


关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/481098?spm=5176.21213303.J_qCOwPWspKEuWcmp8qiZNQ.318.6bb82f3dSLrB4q&scm=20140722.S_community@@%E9%97%AE%E7%AD%94@@481098._.ID_481098-RL_seata%E5%BC%82%E5%B8%B8-LOC_search~UND~community~UND~item-OR_ser-V_3-P0_17


问题三:Seata中异常被捕获就不会回滚了吗?


Seata中异常被捕获就不会回滚了吗?seata只能使用在方法入口吗?如果A方法调用同一个类的B方法,B方法抛出异常被A捕获,则不会回滚吗?


参考回答:

mq消息消费后不抛出异常,捕获了异常offset提交吗?本地事务捕获了异常事务提交吗?不抛异常走什么回滚呀


关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/467620?spm=5176.21213303.J_qCOwPWspKEuWcmp8qiZNQ.323.6bb82f3dSLrB4q&scm=20140722.S_community@@%E9%97%AE%E7%AD%94@@467620._.ID_467620-RL_seata%E5%BC%82%E5%B8%B8-LOC_search~UND~community~UND~item-OR_ser-V_3-P0_18


问题四:动态数据源使用下seata如果出现异常回滚后拿不到对应数据源,这种问题seata有解决方案吗?


Seata中动态数据源使用下seata如果出现异常回滚后拿不到对应数据源,这种问题seata有解决方案吗?


参考回答:

物理数据源手动代理,动态数据源关闭自动代理,建议看下baomidou那个动态代理组件怎么做的。


关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/463550?spm=5176.21213303.J_qCOwPWspKEuWcmp8qiZNQ.328.6bb82f3dSLrB4q&scm=20140722.S_community@@%E9%97%AE%E7%AD%94@@463550._.ID_463550-RL_seata%E5%BC%82%E5%B8%B8-LOC_search~UND~community~UND~item-OR_ser-V_3-P0_19


问题五:Seata中发生下面异常是什么原因啊?


Seata中发生下面异常是什么原因啊? java.lang.NoSuchMethodError: com.fasterxml.jackson.databind.jsontype.TypeSerializer.typeId(Ljava/lang/Object;Lcom/fasterxml/jackson/core/JsonToken;)?


参考回答:

undolog序列化配置为jackson时,jackson版本需要为2.9.9+。或者序列化方式换成kryo。


关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/437022?spm=5176.21213303.J_qCOwPWspKEuWcmp8qiZNQ.353.6bb82f3dSLrB4q&scm=20140722.S_community@@%E9%97%AE%E7%AD%94@@437022._.ID_437022-RL_seata%E5%BC%82%E5%B8%B8-LOC_search~UND~community~UND~item-OR_ser-V_3-P0_20



相关文章
|
6月前
|
Kubernetes Cloud Native Java
Seata常见问题之回滚一直在重试如何解决
Seata 是一个开源的分布式事务解决方案,旨在提供高效且简单的事务协调机制,以解决微服务架构下跨服务调用(分布式场景)的一致性问题。以下是Seata常见问题的一个合集
|
6月前
|
Nacos 数据库 开发者
Seata回滚问题之异常如何解决
Seata是一款开源的分布式事务解决方案,旨在提供高效且无缝的分布式事务服务;在集成和使用Seata过程中,开发者可能会遇到不同的异常问题,本合集针对Seata常见异常进行系统整理,为开发者提供详细的问题分析和解决方案,助力高效解决分布式事务中的难题。
488 12
|
6月前
|
开发者
seata事务问题之不回滚客户端如何解决
Seata是一款开源的分布式事务解决方案,旨在提供高效且无缝的分布式事务服务;在集成和使用Seata过程中,开发者可能会遇到不同的异常问题,本合集针对Seata常见异常进行系统整理,为开发者提供详细的问题分析和解决方案,助力高效解决分布式事务中的难题。
415 11
|
6月前
|
SQL API 数据库
Seata AT模式问题之抛出异常触发回滚如何解决
Seata是一款开源的分布式事务解决方案,旨在提供高效且无缝的分布式事务服务;在集成和使用Seata过程中,开发者可能会遇到不同的异常问题,本合集针对Seata常见异常进行系统整理,为开发者提供详细的问题分析和解决方案,助力高效解决分布式事务中的难题
551 12
|
6月前
|
数据库 开发者
Seata调用问题之全局异常捕获没法回滚如何解决
Seata是一款开源的分布式事务解决方案,旨在提供高效且无缝的分布式事务服务;在集成和使用Seata过程中,开发者可能会遇到不同的异常问题,本合集针对Seata常见异常进行系统整理,为开发者提供详细的问题分析和解决方案,助力高效解决分布式事务中的难题。
505 6
|
1月前
|
消息中间件 Java 数据库
新版 Seata 集成 RocketMQ事务消息,越来越 牛X 了!阿里的 Seata , yyds !
这里 借助 Seata 集成 RocketMQ 事务消息的 新功能,介绍一下一个新遇到的面试题:如果如何实现 **强弱一致性 结合**的分布式事务?
新版 Seata 集成 RocketMQ事务消息,越来越 牛X 了!阿里的 Seata , yyds !
|
6月前
|
监控 数据库
在Seata中一张表使用了联合主键,在事务回滚时报异常,改为单个主键,就没有这个异常,如何解决?
在Seata中一张表使用了联合主键,在事务回滚时报异常,改为单个主键,就没有这个异常,如何解决?
|
5月前
|
Apache 开发者
Apache Seata 如何解决 TCC 模式的幂等、悬挂和空回滚问题
【6月更文挑战第8天】Apache Seata 是一款分布式事务框架,解决TCC模式下的幂等、悬挂和空回滚问题。通过记录事务状态处理幂等,设置超时机制避免悬挂,明确标记Try操作成功来处理空回滚。Seata 提供丰富配置和管理功能,确保分布式事务的可靠性和效率,支持复杂事务处理场景,为企业业务发展提供支持。
214 7
|
6月前
|
Dubbo 关系型数据库 MySQL
Seata常见问题之serviceA方法无法注册分支事务到Seata如何解决
Seata 是一个开源的分布式事务解决方案,旨在提供高效且简单的事务协调机制,以解决微服务架构下跨服务调用(分布式场景)的一致性问题。以下是Seata常见问题的一个合集
|
6月前
|
SQL 监控 Java
Seata常见问题之报找不到全局事务可能已经完成如何解决
Seata 是一个开源的分布式事务解决方案,旨在提供高效且简单的事务协调机制,以解决微服务架构下跨服务调用(分布式场景)的一致性问题。以下是Seata常见问题的一个合集
1076 0