Java实战指南|幂等性-公共幂等组件实现

本文探讨了幂等性在分布式系统中的重要性,并介绍了多种幂等性解决方案,如唯一键索引、分布式锁、Token机制等。重点讲解了一种通过注解方式实现的通用幂等组件,该组件利用Redis进行幂等性校验,适用于方法级别的幂等控制。文章提供了一个简化版的实现流程,并鼓励读者根据实际需求进行优化。
摘要由CSDN通过智能技术生成

前言:

幂等性指的是多次操作,结果是一致的,其任意多次执行所产生的影响均与一次执行的影响相同,例如我们多个线程去查询数据库,多次操作数据库数据要保证一致。现在企业级的事项目大部分都是分布式的,而在分布式环境下幂等是非常常见也是我们必须要解决的问题;

常见的幂等解决方案:

  • 唯一键索引
  • 分布式锁 (redis(jedis、redisson)或zookeeper实现)
  • tonken机制 (流水号,防止页面重复提交)
  • 悲观锁(获取数据的时候加锁(锁表或锁行))
  • 乐观锁 (基于版本号version实现, 在更新数据那一刻校验数据)
  • 状态机 (状态变更, 更新数据时判断状态)

我们今天主要说一个代码层面通过注解的形式来实现一个通用幂等组件

其大体流程如下图:

 

设计注解(ElementType.METHOD方法层面): (默认值expireTime为过期时间也就是一定时间内要求 当前用户当前任务只能执行一次)


import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPo
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值