Redis缓存设计与性能优化【缓存和数据库不一致问题,解决方案:1.加过期时间这样可以一段时间后自动刷新 2.分布式的读写锁】

Redis缓存设计与性能优化

缓存与数据库双写不一致

在大并发下,同时操作数据库与缓存会存在数据不一致性问题

1、双写不一致情况

2、读写并发不一致

解决方案:

1、对于并发几率很小的数据(如个人维度的订单数据、用户数据等),这种几乎不用考虑这个问题,很少会发生缓存不一致,可以给缓存数据加上过期时间,每隔一段时间触发读的主动更新即可。

2、就算并发很高,如果业务上能容忍短时间的缓存数据不一致(如商品名称,商品分类菜单等),缓存加上过期时间依然可以解决大部分业务对于缓存的要求。

3、如果不能容忍缓存数据不一致,可以通过加分布式读写锁保证并发读写或写写的时候按顺序排好队,读读的时候相当于无锁。

4、也可以用阿里开源的canal通过监听数据库的binlog日志及时的去修改缓存,但是引入了新的中间件,增加了系统的复杂度。

总结:

以上我们针对的都是读多写少的情况加入缓存提高性能,如果写多读多的情况又不能容忍缓存数据不一致,那就没必要加缓存了,可以直接操作数据库。当然,如果数据库抗不住压力,还可以把缓存作为数据读写的主存储,异步将数据同步到数据库,数据库只是作为数据的备份。

放入缓存的数据应该是对实时性、一致性要求不是很高的数据。切记不要为了用缓存,同时又要保证绝对的一致性做大量的过度设计和控制,增加系统复杂性!

相关推荐
类似不类似23 分钟前
mysql实例是什么?
数据库·mysql·adb
B.-28 分钟前
前端静态资源缓存与部署实践总结
前端·javascript·缓存·html
hui函数1 小时前
订单后台管理系统-day07菜品模块
数据库·后端·python·flask
知彼解己1 小时前
数据库事务隔离级别与 MVCC 机制详解
数据库
阿里云大数据AI技术2 小时前
阿里云携手MiniMax构建云原生数仓最佳实践:大模型时代的 Data + AI 数据处理平台
大数据·数据库
小蒜学长2 小时前
vue飞自在酒店管理系统(代码+数据库+LW)
java·数据库·spring boot·后端
一行•坚书2 小时前
怎么用redis lua脚本实现各分布式锁?Redisson各分布式锁怎么实现的?
redis·分布式·lua
你我约定有三2 小时前
Redis--Lua脚本以及在SpringBoot中的使用
spring boot·redis·lua
宁小法2 小时前
lua脚本在redis中执行是否是原子性?
redis·lua·阻塞·原子性·回滚
宁小法2 小时前
lua脚本在redis中如何单步调试?
redis·lua·调试