AOP实现LCN分布式事务手动回滚

  由于项目用了较为完善的异常处理机制,导致微服务在抛出异常时,立即被@ExpectionHandler捕捉掉了,造成LCN分布式事务无法捕捉到异常而无法回滚的情况。在查看LCN原理的时候,偶然发现可以获取LCN管理事务的事务组代号groupId,由此想到能不能通过这个ID来手动回滚达到目的。

  原理

   1.在被调用服务异常抛出后,ExceptionHandler进行捕捉并会返回这些错误信息给被服务调用者,如果微服务调用成功,信息中错误码等于10000,如果不成功,那么错误码是不会等于10000的。那么在服务调用者将这些信息return之后,可以用aop来判断信息是否等于10000,如果不等于,拿到事务组groupId进行手动回滚。

  2.如果获取LCN的groupId?LCN源码里有一个

MQTxManagerService

直接注入它:

  @Autowired
  MQTxManagerService mqTxManagerService;

  然后TxTransactionLocal.current().getGroupId()拿到groupId,向tx-manager发送关闭事务的请求。

 @AfterReturning(value = "firstPointCut()",returning = "result")
    public void rollback(JoinPoint joinPoint, Object result){
        if(result instanceof BizRespDto){
            BizRespDto bizRespDto = (BizRespDto) result;

            if(bizRespDto.getCode() != 10000){
                logger.info("过程出现异常,分布式事务开始手动回滚");
                int res
  = mqTxManagerService.closeTransactionGroup(TxTransactionLocal.current().getGroupId(),0);
                logger.info("分布式事务手动回滚结束");
                if(res == 0){
                    logger.info("手动关闭事务组的返回响应:{},没有正常通知执行",res);
                }else{
                    logger.info("手动关闭事务组的返回响应:{},正常通知执行",res);
                }
            }
        }
    }

 

你可能感兴趣的:(AOP实现LCN分布式事务手动回滚)