欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot使用Redisson實現(xiàn)分布式鎖(秒殺系統(tǒng))

 更新時間:2019年12月26日 10:14:27   作者:水能載舟,亦能覆舟  
這篇文章主要為大家詳細介紹了SpringBoot使用Redisson實現(xiàn)分布式鎖,秒殺系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

前面講完了Redis的分布式鎖的實現(xiàn),接下來講Redisson的分布式鎖的實現(xiàn),一般提及到Redis的分布式鎖我們更多的使用的是Redisson的分布式鎖,Redis的官方也是建議我們這樣去做的。Redisson點我可以直接跳轉(zhuǎn)到Redisson的官方文檔。

1.1、引入Maven依賴

<dependency>
 <groupId>org.redisson</groupId>
 <artifactId>redisson-spring-boot-starter</artifactId>
 <version>3.10.6</version>
</dependency>

注意:我這里引入的是redisson和springboot的集成包,網(wǎng)上一些教程可能是引入如下配置

<dependency>
 <groupId>org.redisson</groupId>
 <artifactId>redisson</artifactId>
 <version>3.6.1</version>
</dependency>

如果你引入的就是redisson的依賴包,如果該依賴包的版本低于3.5會需要你再引入

<dependency>
 <groupId>io.netty</groupId>
 <artifactId>netty-all</artifactId>
 <version>4.1.25.Final</version>
</dependency>
 
<dependency>
 <groupId>com.fasterxml.jackson.core</groupId>
 <artifactId>jackson-core</artifactId>
 <version>2.9.0</version>
</dependency>
 
<dependency>
 <groupId>com.fasterxml.jackson.core</groupId>
 <artifactId>jackson-databind</artifactId>
 <version>2.9.0</version>
</dependency>

這樣的一些依賴。

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

新建一個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: !<org.redisson.codec.JsonJacksonCodec> {}
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 "創(chuàng)建訂單成功";
}

1.7、使用ab做接口測試

ab -n 300 -c 300 請求地址

-n 的含義就是你做多少個請求

-c 的含義就是多少個用戶并發(fā)請求

數(shù)據(jù)庫中的商品已經(jīng)全部被秒殺完 并未出現(xiàn)超庫存的情況。

如果對ab不是太了解可以看看這篇文章:使用Apache ab進行http性能測試

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Google Guava 緩存工具使用詳解

    Google Guava 緩存工具使用詳解

    這篇文章主要介紹了Guava自加載緩存LoadingCache使用指南,通過這些內(nèi)容介紹,了解了LoadingCache的基本原理和用法,包括如何創(chuàng)建和配置緩存,以及如何結合Java?8的特性來優(yōu)化代碼,需要的朋友可以參考下
    2023-12-12
  • SpringBoot注解@Import原理之關于ConfigurationClassPostProcessor源碼解析

    SpringBoot注解@Import原理之關于ConfigurationClassPostProcessor源碼解析

    這篇文章主要介紹了SpringBoot注解@Import原理之關于ConfigurationClassPostProcessor源碼解析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 基于Zookeeper實現(xiàn)分布式鎖詳解

    基于Zookeeper實現(xiàn)分布式鎖詳解

    Zookeeper是一個分布式的,開源的分布式應用程序協(xié)調(diào)服務,是Hadoop和hbase的重要組件。這篇文章主要介紹了通過Zookeeper實現(xiàn)分布式鎖,感興趣的朋友可以了解一下
    2021-12-12
  • Spring框架的環(huán)境搭建和測試實現(xiàn)

    Spring框架的環(huán)境搭建和測試實現(xiàn)

    這篇文章主要介紹了Spring框架的環(huán)境搭建和測試實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-10-10
  • 聊聊java中引用數(shù)據(jù)類型有哪些

    聊聊java中引用數(shù)據(jù)類型有哪些

    這篇文章主要介紹了java中引用數(shù)據(jù)類型有哪些,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • 關于JSON解析中獲取不存在的key問題

    關于JSON解析中獲取不存在的key問題

    這篇文章主要介紹了關于JSON解析中獲取不存在的key問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 快速入門介紹Java中強大的String.format()

    快速入門介紹Java中強大的String.format()

    這篇文章主要給大家介紹了如何快速入門介紹Java中強大的String.format()的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2018-03-03
  • springboot+idea+maven 多模塊項目搭建的詳細過程(連接數(shù)據(jù)庫進行測試)

    springboot+idea+maven 多模塊項目搭建的詳細過程(連接數(shù)據(jù)庫進行測試)

    這篇文章主要介紹了springboot+idea+maven 多模塊項目搭建的詳細過程(連接數(shù)據(jù)庫進行測試),本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • SpringBoot中pom.xml配置詳解

    SpringBoot中pom.xml配置詳解

    pom.xml是Maven項目的核心配置文件,用于管理項目的依賴、插件、構建配置等,在Spring Boot項目中,pom.xml文件也扮演著重要的角色,本文將給大家詳細介紹一下SpringBoot中pom.xml配置,需要的朋友可以參考下
    2023-09-09
  • Java(基于Struts2) 分頁實現(xiàn)代碼

    Java(基于Struts2) 分頁實現(xiàn)代碼

    這篇文章介紹了Java(基于Struts2) 分頁實現(xiàn)代碼,有需要的朋友可以參考一下
    2013-10-10

最新評論