分布式系统思考

阅读更多

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

 

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

 

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

 

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

 

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

 

 

你可能感兴趣的:(分布式系统)