Seata分布式事物(四)解决RPC+feign跨服务调用提供者无XID无法回滚问题

事务传播

Seata 全局事务的传播机制就是指事务上下文的传播,根本上,就是 XID 的应用运行时的传播方式。

跨服务调用场景下的事务传播,本质上就是要把 XID 通过服务调用传递到服务提供方,并绑定到 RootContext 中去。

只要能做到这点,理论上 Seata 可以支持任意的微服务框架。

  1. 只要是同一个请求链路,可以将XID作为传输参数传递给服务提供者

  2. 业务方法中获取XID,如下示例
    调用者

    @RequestMapping(value = "testDataApi")
    @GlobalTransactional
    public String testDataApi() throws TransactionException {
        System.out.println("---------XID--------:"+RootContext.getXID());
        // 我的调用方式是RPC+feign跨服务调用
        cn.jbone.common.rpc.Result<Map<String, Object>> data= apiFeign.addData(RootContext.getXID());
        log.info("------tagTree---------={}",tagTree);
        if(data== null){
            log.info("------手动回滚---------");
            // 手动回滚
            GlobalTransactionContext.reload(RootContext.getXID()).rollback();
        }
        return "1";
    }
    

    服务提供者

    @Override
    @RequestMapping(value = "addData", method = {RequestMethod.POST})
    public Result<Map<String, Object>> addData(@RequestParam("xid")String xid) {
    
        // 绑定 XID,自动创建分支事物
        RootContext.bind(xid);
    
        // 异常后,整个调用链路回滚
        int i=10/0;
        return new Result<>(resultMap);
    }
    

// 挂起(暂停)
String xid = RootContext.unbind();
// TODO: 运行在全局事务外的业务逻辑
// 恢复全局事务上下文
RootContext.bind(xid);

官网问题解答的很详细

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值