etcd锁释放超时导致的数据不一致性

      服务端代码:

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

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

      不多说。

发布了2203 篇原创文章 · 获赞 4516 · 访问量 1961万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 技术工厂 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览