什么是幂等
- 简单来说,就是对一个接口执行重复的多次请求,与一次请求所产生的结果是相同的
为什么要实现幂等
- 多次同样的请求进入服务端都执行一遍数据库操作,但有时候这并不是我们业务期望的结果。
实现幂等的几种主要方式
核心:对于多次同样的请求,只执行第一次请求。
-
使用HTTP方法的幂等性
-
在HTTP协议中,某些方法本身就被设计为幂等的,例如
GET
、PUT
、DELETE
。这意味着无论这些请求被发起多少次,服务器上的资源状态都应保持一致。例如,重复调用同一个DELETE
请求删除同一个资源,结果应当是相同的——第一次请求后资源被删除,后续请求对服务器的状态没有改变。
-
-
引入唯一性标识(Idempotency Key)
- 对于通常非幂等的
POST
方法,可以通过在请求中引入一个唯一标识符(例如UUID)作为幂等性键来保持幂等性。服务器根据这个唯一标识判断该操作是否已经执行过。如果是,就不再执行操作,直接返回上一次操作的结果,从而避免重复处理。
- 对于通常非幂等的
-
乐观锁
- 在数据库操作中,乐观锁是一种确保数据一致性的机制,通过在数据中添加版本号或时间戳来实现。每次更新数据前,都检查版本号或时间戳是否与数据库中的一致,如果一致,则进行更新并将版本号加一,确保更新操作的幂等性。
-
Token机制
- 在某些操作(如表单提交)中,可以使用Token来防止重复提交。服务器生成一个唯一的Token,并在客户端表单中返回这个Token。客户端提交表单时携带这个Token,服务器验证Token的有效性,一旦验证通过就执行操作并使Token失效,以防止同一个请求被重复处理。
-
利用数据库约束
- 通过设置数据库的唯一键或主键约束,可以防止重复的记录被插入,从而保证操作的幂等性。例如,如果有一个操作是向数据库插入记录,并且这些记录具有唯一性要求(如用户的电子邮件地址),则可以利用数据库的唯一约束来防止重复插入。