Java高并发秒杀之接口优化

本文介绍了Java高并发秒杀场景下的接口优化措施,包括Redis预减库存减少数据库访问,内存标记来减少Redis访问,以及通过请求入队缓冲和异步下单提升用户体验。详细阐述了每个步骤的操作流程,如系统初始化加载库存到Redis,使用HashMap进行内存标记,以及利用RabbitMQ进行消息队列处理。

在这里插入图片描述

接口优化

Redis预减库存减少数据库的访问
内存标记减少redis访问
请求先入队缓冲,异步下单,增强用户体验
RabbitMQ安装与Spring Boot集成
1、Redis预减库存减少数据库的访问
顾名思义,Redis预减库存减少数据库的访问的思想就是减少对数据库的访问。

  • (1)系统初始化时,将商品库存信息加载到redis中;
  • (2)服务端收到请求后,redis预减库存,如果库存不足,则直接进入下一步;
  • (3)服务端将请求入队,立即返回向客户端返回排队中的信息,提高用户体验;
  • (4)服务端请求出队,生成秒杀订单,减少库存;
  • (5)最后客户端轮询是否秒杀成功。

系统初始化,把商品库存数量加载到Redis
实现接口 InitializingBean

public class MiaoshaController implements InitializingBean{
   
   

实现方法

@Override
public void afterPropertiesSet() throws Exception {
   
   
    List<GoodsVo> goodsVoList =  goodsService.listGoodsVo();
    if (goodsVoList==null){
   
   
        return ;
         }
    for (GoodsVo goodsVo : goodsVoList){
   
   
        //将商品库存加载到redis中  
          redisService.set(GoodsKey.getMiaoshaGoodsStock,""+goodsVo.getId(),goodsVo.getStockCount());
    }
}      

服务端收到请求后,redis预减库存,如果库存不足,则直接进入下一步

//减少库存
<
评论 32
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值