首页>>数据库>>nosql->redis中中如何减库存,redis缓存库存

redis中中如何减库存,redis缓存库存

时间:2023-12-24 本站 点击:0

通过redis+lua实现加减库存

1、我们先分析场景,通过多种方案对比,选用了redis+lua的组合来满足我们的业务需要。利用redis单线程的特点,以及redis6版本后开始对lua的支持,我们采用redis执行lua脚本来确保我们查询+修改的串行执行。

2、如果方案是扣减时候先lua扣redis,扣成功了同步扣mysql,这样可以解决流量大库存少的问题,基本上库存比较少没有啥问题。

3、复用。客户端发送的脚步会永久存在redis中,这样,其他客户端可以复用这一脚本而不需要使用代码完成相同的逻辑。

利用Redis设计库存系统的苦与乐

我们先在Redis中拿到当前的库存值,然后check是否已经扣减到了零,如果已经扣减到了零,则直接return;否则,就利用Redis的decr原子操作进行扣减,同时返回扣减后的库存值。

内存使用效率对比:使用简单的key-value存储的话,Memcached的内存利用率更高,而如果Redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于Memcached。

库存全部放在redis是可取的。商品的库存全部放入redis,库存的读取直接读取redis,到了下单环节,库存的扣除也直接在redis扣除,通过消息队列通知后端数据库,最终把库存的扣减异步同步到后台数据库,避免了对数据库的瞬时压力。

根据目前风控系统运行情况来看,遇到如下的问题 redis 中的key 太多,在存量卡号比较大的情况下,redis 中key的存储过于庞大。 redis 本身RDB 和 AOF 的问题。 线上开启AOF 重写出差情况下,会阻塞redis 主线程。

redismysql库存扣减失败怎么办

如果只用Redis来进行存储,处理完数据直接返回前端即可。如果还要持久化到DB,要尽量避免直接操作DB,因为DB往往是最大的IO瓶颈,如果要异步落库到DB,比如使用MQ。要注意处理Redis扣减和消息发送的原子性处理。

还是用刚才的秒杀举例,我们为的就是保证库存的数据不出错,卖出一个商品,减一个库存,那么,我们就可以将库存放在内存中进行处理。这样,就能够保证库存有序的及时扣减,并且不出现问题。

解决方法:这种情况应该是先删除缓存,然后在更新数据库,如果删除缓存失败,那就不要更新数据库,如果说删除缓存成功,而更新数据库失败,那查询的时候只是从数据库里查了旧的数据而已,这样就能保持数据库与缓存的一致性。

【方案一】http://?sort=created 程序实现mysql更新、添加、删除就删除redis数据。

检查库存(RPC) 锁库存(RPC) 开启事务,插入订单表(MySQL) 调用某些其他下游服务(RPC) 更新订单状态 commit 事务(MySQL) 当消息消费到步骤3的时候,我们假设MySQL异常导致失败了,触发消息重试。

redis中中如何减库存的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于redis缓存库存、redis中中如何减库存的信息别忘了在本站进行查找喔。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:/nosql/56763.html