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

本文介绍了幂等性的概念及其在分布式环境中的重要性,提出了几种常见的幂等解决方案,如唯一键索引、分布式锁、令牌机制等。文章重点讲解了一种基于注解的代码层面实现的通用幂等组件,通过AOP进行注解扫描和幂等校验业务,以Redis为例进行了详细说明,旨在帮助开发者理解和实现幂等性控制。
摘要由CSDN通过智能技术生成

 

前言:

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

常见的幂等解决方案:

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

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

其大体流程如下图:

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


                
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值