redis缓存商品库存减压

本文介绍了如何使用Redis缓存库存以减轻数据库压力,通过系统初始化加载库存、预减库存操作及并发请求处理来避免数据库崩溃。利用 InitializingBean 接口确保启动时加载缓存,使用Map标记库存状态,有效降低Redis和数据库的负担。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

redis缓存库存

Redis预减库存:主要思路减少对数据库的访问,之前的减库存,直接访问数据库,读取库存,当高并发请求到来的时候,大量的读取数据有可能会导致数据库的崩溃。

我们主要是通过这几点来实现的:
1、系统初始化的时候,将商品库存加载到Redis 缓存中保存,并不是需要先请求一次才能缓存
2、.收到请求的时候,现在Redis中拿到该商品的库存值,进行库存预减,如果减完之后库存不足,直接返回逻辑错误,减少对数据库的访问
3、将请求入队,立即给前端返回一个值,表示正在排队中,然后进行秒杀逻辑,减库存–>下订单–>写入秒杀订单,成功了就返回成功,流程只要有一个错误就返回失败,前端同时轮询

首先我们需要实现InitializingBean接口,InitializingBean接口为bean提供了初始化方法的方式,它就包括afterPropertiesSet方法,凡是继承该接口的类,在初始化bean的时候会执行该方法。

	/**
	 *	系统初始化后就将所有商品库存放入 缓存
	 * */
	public void afterPropertiesSet() throws Exception {
   
   
		List<GoodsVo> goodsList = goodsService.listGoodsVo();
		if(goodsList == null) {
   
   
			return;
		}
		for(GoodsVo goods : goodsList) {
   
   
			redisService.set(GoodsKey.getMiaoshaGoodsStock, ""+goods.getId(), goods.getStockCount
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不愿秃头的阳某

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值