网络/事务请求去重

在产品的开发过程中,发现有少数章节重复被创建的情况。分析日志和数据判断是因为服务器接收到重复的请求,而这些请求重复可能有两个原因:客户端重复发送和网络出现重传现象。

对于这两个方面,个人觉得可以从两方面入手:

  1. 请求去重,保证服务器只处理一次,同时也需要使客户端只发送一次
  2. 请求与事务绑定,在事务处理的时候只处理一次

在现实中,我们是使用了第1个方法。在每个Ajax请求后加RequestID防止重复请求的处理,同时客户端修改代码使不会产生连续请求。这里面RequestID由于是由客户端生成的,不能保证唯一性,所以RequestID需要与Nickname关联。

这是一个通用修改,应对的是网络重传问题。但是不能完全解决章节重复创建问题,只是解决了目前看到的出现问题。

那进一步思考,重复创建是不是因为API给server提供的信息不够,导致server无法判断是否应该执行?
如果提供足够的信息量是可以判断请求是否应该执行,但是这个足够的信息量不好选取。选取不当可能导致多终端问题,所以把问题复杂化了。

现在我能想到的是基于事务唯一的方法,但是具体方法得再去研究。

原文地址:https://www.cnblogs.com/shanpow/p/4217759.html