服务端代码:

 
func proc() {
	
	begin lock
	   begin transaction
            amount := queryAmountFromDb()
            amount += req.OrderAmount
            setToDb(amount)
	   end transaction  // 正常结束
	end lock  // 这里是etcd锁,释放的时候,超时了
 
}

       于是乎, 在客户端显示超时, 客户端不知道实际是成功还是失败, 只知道超时, 客户端可以同步/异步重试。 服务端要做到幂等性处理。

      不多说。


本文转载:CSDN博客