redis 分布式锁 java 秒杀_SpringBoot使用Redisson实现分布式锁(秒杀系统)

本文介绍了如何在SpringBoot应用中使用Redisson实现分布式锁,以解决秒杀场景下的并发问题。首先,引入redisson-spring-boot-starter依赖,然后配置Redis连接信息和redisson配置文件,接着创建RedissonConfig配置类并编写秒杀接口,利用RLock进行加锁和解锁操作,确保库存的正确减少。最后通过ab工具进行接口测试,验证了分布式锁的有效性。
摘要由CSDN通过智能技术生成

前面讲完了Redis的分布式锁的实现,接下来讲Redisson的分布式锁的实现,一般提及到Redis的分布式锁我们更多的使用的是Redisson的分布式锁,Redis的官方也是建议我们这样去做的。Redisson点我可以直接跳转到Redisson的官方文档。

1.1、引入Maven依赖

org.redisson

redisson-spring-boot-starter

3.10.6

注意:我这里引入的是redisson和springboot的集成包,网上一些教程可能是引入如下配置

org.redisson

redisson

3.6.1

如果你引入的就是redisson的依赖包,如果该依赖包的版本低于3.5会需要你再引入

io.netty

netty-all

4.1.25.Final

com.fasterxml.jackson.core

jackson-core

2.9.0

com.fasterxml.jackson.core

jackson-databind

2.9.0

这样的一些依赖。

1.2、配置redis信息

spring:

application:

name: spring-cloud-product

redis:

port: 6379

host: 127.0.0.1

password:

database: 0

timeout: 2000

1.3、配置redisson

f6e59af72ce4f992f8e32790a477dee6.png

新建一个redisson-single.yml的配置文件 下面是单机配置

singleServerConfig:

idleConnectionTimeout: 10000

pingTimeout: 1000

connectTimeout: 10000

timeout: 3000

retryAttempts: 3

retryInterval: 1500

reconnectionTimeout: 3000

failedAttempts: 3

password: null

subscriptionsPerConnection: 5

clientName: null

address: "redis://127.0.0.1:6379"

subscriptionConnectionMinimumIdleSize: 1

subscriptionConnectionPoolSize: 50

connectionMinimumIdleSize: 32

connectionPoolSize: 64

database: 0

#在最新版本中dns的检查操作会直接报错 所以我直接注释掉了

#dnsMonitoring: false

dnsMonitoringInterval: 5000

threads: 0

nettyThreads: 0

codec: ! {}

transportMode : "NIO"

1.4、写一个RedissonConfig配置类 来配置你的redisson

/**

* @Description //TODO

* @Date $ $

* @Author huangwb

**/

@Configuration

public class RedssonConfig {

@Bean(destroyMethod="shutdown")

public RedissonClient redisson() throws IOException {

RedissonClient redisson = Redisson.create(

Config.fromYAML(new ClassPathResource("redisson-single.yml").getInputStream()));

return redisson;

}

}

1.5、编写一个秒杀接口

@Autowired

private RedissonClient redissonClient;

@Override

public boolean decrementProductStore(Long productId, Integer productQuantity) {

String key = "dec_store_lock_" + productId;

RLock lock = redissonClient.getLock(key);

try {

//加锁 操作很类似Java的ReentrantLock机制

lock.lock();

ProductInfo productInfo = productInfoMapper.selectByPrimaryKey(productId);

//如果库存为空

if (productInfo.getProductStock() == 0) {

return false;

}

//简单减库存操作 没有重新写其他接口了

productInfo.setProductStock(productInfo.getProductStock() - 1);

productInfoMapper.updateByPrimaryKey(productInfo);

} catch (Exception e) {

System.out.println(e.getMessage());

} finally {

//解锁

lock.unlock();

}

return true;

}

1.6、写一个简单的测试请求

@GetMapping("test")

public String createOrderTest() {

if (!productInfoService.decrementProductStore(1L, 1)) {

return "库存不足";

}

OrderMaster orderMaster = new OrderMaster();

//未支付

orderMaster.setOrderStatus(0);

//未支付

orderMaster.setPayStatus(0);

orderMaster.setBuyerName(name);

orderMaster.setBuyerAddress("湖南长沙");

orderMaster.setBuyerPhone("18692794847");

orderMaster.setOrderAmount(BigDecimal.ZERO);

orderMaster.setCreateTime(DateUtils.getCurrentDate());

orderMaster.setOrderId(UUID.randomUUID().toString().replaceAll("-", ""));

orderMasterService.insert(orderMaster);

return "创建订单成功";

}

1.7、使用ab做接口测试

6c0531686350c907db60663cfc4423ab.png

28fce5dc424f5f5846ef8af54ec59b38.png

c1e520caf1b2ebc0eec3b550a3bfef97.png

ab -n 300 -c 300 请求地址

-n 的含义就是你做多少个请求

-c 的含义就是多少个用户并发请求

数据库中的商品已经全部被秒杀完 并未出现超库存的情况。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值