一套不那么成熟的业务数据查询缓存方案

文章讨论了一种针对高并发、大体积数据查询的解决方案,利用Redis存储key-ids并结合本地缓存存储完整vos。优点是提高效率,缺点是代码复杂度和内存占用。适用于热门数据展示场景。尽管效果良好,但仍需改进。

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

方案如图:
在这里插入图片描述
为什么会有这套方案的产生呢?主要出于以下原因:
1、业务查询接口性能要求较高。读写较频繁。现有数据库经过多轮优化后仍无法满足该要求。
2、普通的将vos结果缓存到redis在查询数据较大和频率擦除更新的情况下,查询性能得不到太大的提升。
3、表数据并非海量,只是关联的表和字段较多,字段内容较多,造成数据包大和查询慢。

方案简介:
1、项目启动时,将全部vos集缓存到本地。将vo的唯一键缓存到reids。
2、取数据时,先去redis取到vo的所有键。然后去本地缓存取到vo对象。组成结果集返回。
3、更新时,redis擦除数据量较小的key-ids,本地将修改或新增的数据刷新到本地缓存。并通过redis自带的发布订阅模式。将更新消息扩散到其他集群节点。

优点:
redis无需缓存vo大对象,更新时也不需要操作vo。只缓存key-ids,效率较高。
本地缓存读取vo速度快。
本地缓存更新数据只需在很小的范围内更新。比如新增,直接往本地缓存写一条k-vo。修改,直接修改k-vo。

缺点:
代码复杂,代码量较大。
占用服务器内存资源。

综上所述。主要作用于客户使用较热门的一些重要数据的展示。如报表、滚动大屏什么的。该方案最近急赶急试了下。感觉还不错。但可能还存在不少缺陷。仅供参考。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值