Java实现高并发秒杀的几种方式

 更新时间:2023年05月23日 15:51:50   作者:fking86  
高并发场景在现场的日常工作中很常见,本文主要介绍了Java实现高并发秒杀的几种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

引言

高并发场景在现场的日常工作中很常见,特别是在互联网公司中,这篇文章就来介绍如何实现高并发秒杀的几种方式。

实现方式

1.缓存

使用缓存可以减少数据库的访问量,提高系统吞吐量。可以缓存热点数据、查询结果等。

@Cacheable(value = "goods", key = "#goodsId")
public Goods getGoods(Integer goodsId) {
    // 查询数据库
}

2.前端实现方式

通过前端 JS 代码限制用户请求频率,避免过大流量涌入,导致系统崩溃。比如可以实现每秒钟限制请求次数等。

var requestTimes = 0; 
var lastRequestTime = 0;
function requestSecKill() {
    var now = new Date();
    if (now - lastRequestTime < 1000 && requestTimes > 5) {
        alert('请求过于频繁,请稍后再试!');
        return;
    }
    lastRequestTime = now;
    requestTimes++;
    // 发送秒杀请求
}

3.队列削峰

当请求流量超过系统容量时,暂存多余请求到消息队列,然后逐渐削峰处理。比如定时从队列中取出一定数量请求处理。

BlockingQueue<Runnable> queue = new ArrayBlockingQueue<>(1000);
​
public void addTask(Runnable task) {
    boolean offered = queue.offer(task);
    if (!offered) {
        // 队列满了,请求太多,返回限流提示
    }
}
​
public void handleTasks() {
    Runnable task = queue.poll();
    if (task != null) {
        executor.execute(task);
    }
}

4.限流

使用令牌桶或者漏桶算法根据系统容量限制请求通过速率。超过速率的请求被拒绝或进入队列等待。

RateLimiter rateLimiter = RateLimiter.create(10); // 每秒不超过10个请求 
if (rateLimiter.tryAcquire()) {
    // 请求通过
} else {
   // 请求超过限流频率
}

5.数据库读写分离

将数据库分成主库和从库,秒杀相关读操作从从库读取,防止主库压力过大。

@Autowired
private GoodsRepository goodsRepository;
​
public Goods getGoods(Integer goodsId) {
    // 读取从库
    return goodsRepository.read(goodsId); 
}
​
public void reduceStock(Integer goodsId) {
    // 写入主库
    goodsRepository.write(goodsId);
}

6.缓存失效时间

可以根据系统负载动态调整缓存失效时间,在高流量期间缩短失效时间,避免缓存相同数据长时间。

@Cacheable(value = "goods", key = "#goodsId", expire = "#expireTime")
public Goods getGoods(Integer goodsId, Integer expireTime) {
    // 查询数据库
}
​
// 调整失效时间
cacheManager.setCacheExpired(cacheName, expireTime); 

7.版本控制

对缓存或商品数据设置版本号,当数据修改时版本号递增。请求带上版本号,如果缓存版本低,则从数据库重新加载数据。可以确保用户获取最新数据。

后端:

@Cacheable(value = "goods", key = "#goodsId + #version") 
public Goods getGoods(Integer goodsId, Integer version) {
    // 查询数据库,带版本号校验
}
​
public void updateGoods(Integer goodsId, Integer version) {
    goods.setVersion(version + 1);
    // 更新数据库  
}

前端:

$.get("/goods/" + goodsId + "?v=" + version, function(data) {
     // 处理返回结果
});

总结

如果要完美解决高并发场景,需要 从缓存、限流、消息队列、数据库扩展多方面考虑,而不仅仅是一两个技术就可以。还需要注意系统的稳定性、扩展性,要足够灵活与健壮。

到此这篇关于Java实现高并发秒杀的几种方式的文章就介绍到这了,更多相关Java 高并发秒杀内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解IntelliJ IDEA中TortoiseSVN修改服务器地址的方法

    详解IntelliJ IDEA中TortoiseSVN修改服务器地址的方法

    这篇文章主要介绍了详解IntelliJ IDEA中TortoiseSVN修改服务器地址的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-12-12
  • 如何使用lamda表达式对list进行求和

    如何使用lamda表达式对list进行求和

    这篇文章主要介绍了如何使用lamda表达式对list进行求和问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • Mybatis selectKey 如何返回新增用户的id值

    Mybatis selectKey 如何返回新增用户的id值

    这篇文章主要介绍了Mybatis selectKey 如何返回新增用户的id值,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • Mybatis或Mybatis-Plus框架的xml文件中特殊符号的使用详解

    Mybatis或Mybatis-Plus框架的xml文件中特殊符号的使用详解

    这篇文章主要介绍了Mybatis或Mybatis-Plus框架的xml文件中特殊符号的使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • 浅谈Java编程中的synthetic关键字

    浅谈Java编程中的synthetic关键字

    这篇文章主要介绍了浅谈Java编程中的synthetic关键字的相关内容,包括其简单的介绍和实例,需要的朋友可以了解下。
    2017-09-09
  • Java实现Word/Pdf/TXT转html的实例代码

    Java实现Word/Pdf/TXT转html的实例代码

    本文主要介绍了Java实现Word/Pdf/TXT转html的实例代码,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • dubbo服务链路跟踪方式

    dubbo服务链路跟踪方式

    这篇文章主要介绍了dubbo服务链路跟踪方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • Java实现微信小程序加密数据解密算法

    Java实现微信小程序加密数据解密算法

    我们开发微信小程序的过程中,我们的服务端有时需要获取微信提供的开放数据。微信会对这些开放数据做签名和加密处理,本文通过实例代码给大家介绍Java实现微信小程序加密数据解密算法,感兴趣的朋友一起看看吧
    2021-11-11
  • kotlin和Java的相互调用示例详解

    kotlin和Java的相互调用示例详解

    Kotlin 的设计过程中就考虑到了与 Java 的互操作性。在 Kotlin 中可以直接调用既有的 Java 代码, 反过来在 Java 中也可以很流畅地使用 Kotlin 代码,下面这篇文章主要给大家介绍了关于kotlin和Java的相互调用的相关资料,需要的朋友可以参考下。
    2018-02-02
  • 详解Java实现缓存(LRU,FIFO)

    详解Java实现缓存(LRU,FIFO)

    本篇文章主要介绍了详解Java实现缓存(LRU,FIFO) ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04

最新评论