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