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

Redis缓存设计与性能优化

缓存与数据库双写不一致

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

1、双写不一致情况

2、读写并发不一致

解决方案:

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

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

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

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

总结:

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

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

相关推荐
sniper_fandc10 分钟前
Redis原理之持久化
数据库·redis·缓存
打野二师兄1 小时前
生产问题排查-数据库连接池耗尽
数据库·oracle
℡余晖^2 小时前
分布式全局唯一ID生成:雪花算法 vs Redis Increment,怎么选?
数据库·redis·缓存
代码老y2 小时前
缓存穿透的“黑暗森林”假说——当攻击者学会隐藏恶意流量
缓存
丁丁点灯o3 小时前
Oracle日期时间函数说明及与MySql区别说明
数据库·mysql·oracle
qq_157852073 小时前
Oracle 查找连续日期连续小时
数据库·sql·mysql
lovix123 小时前
MySQL高级篇(二):深入理解数据库事务与MySQL锁机制
数据库·mysql
和麻3 小时前
sqlserver迁移日志文件和数据文件
数据库
StarRocks_labs9 小时前
StarRocks Community Monthly Newsletter (Jun)
数据库·starrocks·数据湖·物化视图·存算分离
光电的一只菜鸡10 小时前
ubuntu之坑(十五)——设备树
linux·数据库·ubuntu