B站秒杀项目学习心得

项目地址:B站大学
特别鸣谢:某大佬博客

在该项目中核心就是秒杀的实现:大量用户进行秒杀订单时不能超卖、同一用户不能重复抢

不能超卖在doSeckill1中通过update的排他性实现(乐观锁)。

        //拿到秒殺商品
        TSeckillGoods seckillGoods = itSeckillGoodsService.getOne(new QueryWrapper<TSeckillGoods>().eq("goods_id", goodsVo.getId()));
        seckillGoods.setStockCount(seckillGoods.getStockCount() - 1);
        //id没问题同时库存>0才更新
        boolean seckillGoodsResult = itSeckillGoodsService.update(new UpdateWrapper<TSeckillGoods>()
                .setSql("stock_count = " + "stock_count-1")
                .eq("goods_id", goodsVo.getId())
                .gt("stock_count", 0)
        );

而在doSeckill2中通过redis预减库存(redis的原子性实现)

        //通过Redis预减库存
        ValueOperations valueOperations = redisTemplate.opsForValue();
        TSeckillOrder seckillOrder =
           (TSeckillOrder) redisTemplate.opsForValue().get("order:"+user.getId()+":"+goodsId);
        if(seckillOrder != null) return RespBean.error(RespBeanEnum.REPEATE_ERROR);
        Long stock = valueOperations.decrement("seckillGoods:"+goodsId);
        if(stock < 0){
            valueOperations.increment("seckillGoods:"+goodsId);
            return RespBean.error(RespBeanEnum.EMPTY_STOCK);
                    }
//        通过RabbitMQ消息队列下单
        return  RespBean.success(order);
  • 不能重复抢通过唯一索引实现:即将商品id和用户id进行绑定构成唯一索引
  • 压测可以把用户加少点商品多一点就可以复现重复购买
  • 优化主要是把数据库的重复访问,能放到redis就放到redis

前人之述备矣,我想说一下做这个项目的心得:

坚持自己实现一遍,看再多次也只是看,一定要写代码,你会发现就算有视频,有参考,还是会有很多bug,半天的项目视频,我前后花了4天才完全实现,这里还不能说全都明白。
但是收获巨大,对很多只停留于脑海的知识点有更深的理解,如访问Redis确实比访问数据库快;在高并发场景下如何保证数据一致性(唯一性索引,乐观锁,原子性操作)等等。
同时也遇到了很多bug,例如设置cookie时会出现同名cookie第一个值为null导致后端取不到数据;因为单词大小写导致无法接受到请求;数据库部分用户信息不全导致无法添加报空指针异常。。。
希望自己能多动手,多思考,加油!

相关推荐

  1. B项目学习心得

    2024-04-27 07:28:03       37 阅读
  2. 业务

    2024-04-27 07:28:03       53 阅读
  3. 业务

    2024-04-27 07:28:03       53 阅读
  4. Redis实现

    2024-04-27 07:28:03       45 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-27 07:28:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-27 07:28:03       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-27 07:28:03       87 阅读
  4. Python语言-面向对象

    2024-04-27 07:28:03       96 阅读

热门阅读

  1. Elasticsearch简介及安装

    2024-04-27 07:28:03       28 阅读
  2. 数据结构常见算法

    2024-04-27 07:28:03       34 阅读
  3. go中标签创建与引用

    2024-04-27 07:28:03       28 阅读
  4. Android常用开源库所使用的设计模式有哪些?

    2024-04-27 07:28:03       33 阅读
  5. sym和syms--Matlab学习

    2024-04-27 07:28:03       35 阅读
  6. 大模型流式任务转发终结篇python版本实现

    2024-04-27 07:28:03       35 阅读
  7. Ajax学习笔记

    2024-04-27 07:28:03       30 阅读
  8. UE_反射系统(虚幻编译系统)

    2024-04-27 07:28:03       39 阅读