分布式系统思考

分布式系统一般会碰到两个问题。

 

一是多个服务处于一个事务中时,某一个服务挂掉后的处理。

 

比如订单预处理时,需要调用扣减库存服务和扣减税金服务。当扣减库存成功后,调用扣减税金服务失败时,

 

如果直接终止订单预处理就会导致订单已经被扣减库存,但还是初始化状态。一般在终止订单预处理,需要调用返还库存的服务,如果调用返还服务时失败,可以记入事件等待补偿任务去处理。

 

另外一种就是超时问题。当我调用某个服务时,如果服务处理时间较长,就会在规定时间没有返回成功,导致超时,实际上后台还在处理这个任务。系统会认为这次处理失败,下次会继续调用这个服务。如果服务发现在该任务刚才已经处理了,直接返回失败。就会导致系统不停的调用该服务。这时需要将接口设计成第二次调用的时候,如果发现该任务已经处理,则直接返回成功,而不是失败。

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值