springboot redis分布式锁代码实例
这篇文章主要介绍了springboot redis分布式锁代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
随着微服务等分布式架构的快速发展及应用,在很多情况下,我们都会遇到在并发情况下多个线程竞争资源的情况,比如我们耳熟能详的秒杀活动,多平台多用户对同一个资源进行操作等场景等。分布式锁的实现方式有很多种,比如基于数据库、Zookeeper、Redis等,本文我们主要介绍Spring Boot整合Redis实现分布式锁。
工具类如下:
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisCallback; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.serializer.RedisSerializer; import org.springframework.stereotype.Component; import redis.clients.jedis.Protocol; import redis.clients.util.SafeEncoder; import java.io.Serializable; @Component public class RedisUtils { @Autowired private RedisTemplate redisTemplate; public RedisTemplate getRedisTemplate() { return this.redisTemplate; } /** * 设置redis分布式锁 * @param key * @param value * @param expire 锁过期时间 * @return */ public boolean tryLock(final String key, final Serializable value, final long expire){ boolean isSuccess = (boolean) redisTemplate.execute((RedisCallback) connection -> { RedisSerializer valueSerializer = redisTemplate.getValueSerializer(); RedisSerializer keySerializer = redisTemplate.getKeySerializer(); Object object = connection.execute("set",keySerializer.serialize(key),valueSerializer.serialize(value), SafeEncoder.encode("NX"),SafeEncoder.encode("EX"), Protocol.toByteArray(expire)); return null != object; }); return isSuccess; } //释放锁 public boolean releaseLock(String key){ return redisTemplate.delete(key); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
上一篇:Spring实战之使用ClassPathResource加载xml资源示例
栏 目:Java
下一篇:Spring实战之ServletContextResource访问资源文件示例
本文地址:https://www.xiuzhanwang.com/a1/Java/8815.html
您可能感兴趣的文章
- 01-10Springboot中@Value的使用详解
- 01-10springboot实现文件上传步骤解析
- 01-10springboot jta atomikos实现分布式事物管理
- 01-10SpringBoot使用RabbitMQ延时队列(小白必备)
- 01-10如何基于SpringBoot部署外部Tomcat过程解析
- 01-10springboot集成fastDfs过程代码实例
- 01-10SPRINGBOOT读取PROPERTIES配置文件数据过程详解
- 01-10springboot 配置DRUID数据源的方法实例分析
- 01-10springboot2.0使用Hikari连接池的方法(替换druid)
- 01-10springboot单元测试两种方法实例详解
阅读排行
本栏相关
- 01-10Java实现动态模拟时钟
- 01-10Springboot中@Value的使用详解
- 01-10JavaWeb实现邮件发送功能
- 01-10利用Java实现复制Excel工作表功能
- 01-10Java实现动态数字时钟
- 01-10java基于poi导出excel透视表代码实例
- 01-10java实现液晶数字字体显示当前时间
- 01-10基于Java验证jwt token代码实例
- 01-10Java动态显示当前日期和时间
- 01-10浅谈Java中真的只有值传递么
随机阅读
- 04-02jquery与jsp,用jquery
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法实例总结
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-10SublimeText编译C开发环境设置
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-11ajax实现页面的局部加载
- 01-10使用C语言求解扑克牌的顺子及n个骰子