业务设计---不用redis分布式锁, 如何防止用户重复点击?

✅不用redis分布式锁, 如何防止用户重复点击?

当不让使用redis分布式锁,或者集群不可用的时候,如何做到防止用户重复点击的功能呢?

有以下几个思路可以供大家参考:

1、前端需要做一些按钮置灰

1、首先就是前端需要做一些按钮置灰的动作,让用户点击一次之后,按钮就直接禁用调,让用户无法重复点击。但是有些情况可能没来得及置灰就重复点击了,或者有些用户自己绕过了置灰也可以点击。

2、token的机制避免重复提交

2、可以通过token的机制避免重复提交,当用户访问页面的时候,请求后端服务拿到一个token,然后下一次接口点击的时候把token带过来,服务端对token进行验证,验证该token是否被使用过,如果没有被使用过才可以进行点击。验证的逻辑可以放在数据库中,通过数据库的悲观锁或者乐观锁都可以实现。

比如,以下就是我自己的项目中,通过token来进行订单防重复的一个具体的交互图:

3、滑动窗口限流

滑动窗口限流,滑动窗口限流是一种流量控制策略,用于控制在一定时间内允许执行的操作数量或请求频率。我们可以限制一分钟或者一秒钟内用户只能发起一次请求来防止重复点击。

4、布隆过滤器

可以使用布隆过滤器,他可以快速判断某个元素是否存在于集合中。可以在服务器端使用布隆过滤器记录某个操作是否已经被执行过,从而防止重复执行。

如果布隆过滤器不存在,则一定不存在,所以,如果没查到,说明一定没有幂等操作,直接执行就行了。

如果查询布隆过滤器发现有命中,则需要在服务数据库做一次幂等判断。

大多数情况下,需要幂等的情况占比小,所以可以用布隆过滤器做一次fail-fast的快速校验。

Redis其实也是一个集中式的存储服务,在特殊情况下,如果无法使用,一般的做法都是降级成直接使用数据库。

参考 ruoyi

5、还有种方式,那就是参考 ruoyi 框架中的防重复提交的实现方案,其实就是把表单信息做校验并保存在 REDIS 中,下次再提交的时候做校验,如果和上次提交的内容一样,并且时间小于一定的时间间隔,则拒绝请求

相关推荐
架构师老Y4 分钟前
013、数据库性能优化:索引、查询与连接池
数据库·python·oracle·性能优化·架构
王码码20357 分钟前
Go语言中的Elasticsearch操作:olivere实战
后端·golang·go·接口
Kel8 分钟前
PydanticAI 源码深潜:类型安全依赖注入与图执行引擎的双核架构解析
人工智能·python·架构
十有八七13 分钟前
OpenHarness 架构说明文档
人工智能·架构
贵慜_Derek19 分钟前
Managed Agents 里,Harness 到底升级了什么?
人工智能·算法·架构
Tadas-Gao22 分钟前
从“驯马”到“驭队”:Harness Engineering 如何重构 AI 产品化的底层逻辑
人工智能·语言模型·架构·大模型·llm·harness
wasp52030 分钟前
从 Vibe Coding 到真·生产力:OpenHarness 的“Harness 方程式”及其实战分析
人工智能·架构·开源·agent
OpenCSG31 分钟前
OpenClaw × AgenticHub 架构解析:智能体系统如何真正具备执行能力
架构
小旭952733 分钟前
Spring Security 实现权限控制(认证 + 授权全流程)
java·后端·spring
weixin_4080996734 分钟前
【完整教程】天诺脚本如何调用 OCR 文字识别 API?自动识别屏幕文字实战(附代码)
前端·人工智能·后端·ocr·api·天诺脚本·自动识别文字脚本