上一篇 <<<Redis分布式锁的实现代码示例
下一篇 >>>Redis集群模式之主从复制原理及存在的缺陷
1、引入redisson依赖包
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson-spring-boot-starter</artifactId>
<version>3.11.0</version>
</dependency>
2、增加配置文件
redisson.singleServerConfig.address=127.0.0.1:6379
3、Redisson实现分布式锁
@GetMapping("/seckill")
public synchronized String seckill() throws InterruptedException {
RLock seckillLock = redissonClient.getLock("seckillLock");
try {
seckillLock.tryLock(3, TimeUnit.SECONDS);
String stock = stringRedisTemplate.opsForValue().get("Stock");
int nStock = Integer.valueOf(stock) - 1;
if (nStock > 0) {
//成功秒杀到
nStock = Integer.valueOf(stock) - 1;
stringRedisTemplate.opsForValue().set("Stock", nStock + "");
System.out.println("成功秒杀商品了,还剩余商品:" + nStock);
return "恭喜您,下单成功";
}
} catch (Exception e) {
e.printStackTrace();
} finally {
seckillLock.unlock();
}
System.out.println("商品库存不足");
return "当前库存不足";
}
4、getLock和tryLock的区别
tryLock(long time, TimeUnit unit)方法和tryLock()方法是类似的,只不过区别在于这个方法在拿不到锁时会等待一定的时间,在时间期限之内如果还拿不到锁,就返回false。如果一开始拿到锁或者在等待期间内拿到了锁,则返回true。
推荐阅读:
<<<分布式缓存与本地缓存的区别
<<<Ehcache基础知识
<<<SpringBoot整合Ehcache
<<<Redis的5种数据类型
<<<Redis存放实体对象的方式及区别
<<<Redis的应用场景汇总
<<<Redis高效及线程安全的真正原因
<<<Redis为啥要分为16个库
<<<RDB和AOF持久化方式的区别
<<<Redis与数据库的一致性解决方案
<<<SpringBoot整合Redis的注解版本完成数据缓存
<<<Redis的淘汰策略
<<<Redis的事务操作(Mult和Watch)知识点
<<<Redis的过期机制使用场景示例
<<<Redis实现分布式锁的原理分析
<<<Redis分布式锁的实现代码示例
<<<Redis集群模式之主从复制原理及存在的缺陷
<<<Redis集群模式之哨兵模式
<<<Redis集群模式之Cluster去中心化分片集群
<<<Linux环境下安装单机Redis
<<<Redis Cluster集群环境搭建
<<<Redis Cluster如何动态扩容与缩容
<<<Redis Cluster主从节点自动切换
<<<Redis集群模式的类型和缺陷汇总
<<<Redis缓存的穿透、击穿和雪崩效应
<<<Redis解决穿透击穿问题时使用的布隆过滤器知识点
<<<Redis与MySQL的数据同步解决方案
<<<阿里云的Canal框架实现Redis与Mysql同步原理及代码示例
<<<阿里云的Canal框架配置
<<<Redis官方提出的redlock分布式锁
<<<Redis的调优设置
<<<Redis常见问题汇总