系列文章是博主对沈剑的《架构师训练营》分享内容的个人笔记总结,原内容公众号“成为架构师”。
什么是进程内缓存
例如:
- 带锁的Map
- level级别的db
具有的优势
与没有缓存的比较:
- 有了进程缓存可以加速数据访问,不用查询数据库
与缓存集群比较
- 节省内网带宽
- 时延更低
进程内缓存的缺陷和解决方法
最严重的问题:缓存一致性问题
数据的冗余必然造成一致性问题,而进程内缓存是每一个进程一份缓存,不同缓存之间会有一致性问题
解决方案主要有三个:
1 单节点通知
当一个进程内的缓存数据修改的时候它就向它的兄弟节点广播修改的信息,通知它们与它修改的内容的同步

缺点:
- 各节点紧耦合
- 实现复杂,进程要关注本身不需要关注的内容
- 通信量大
2 使用MQ解耦
节点不是向其它节点广播通知,而是将修改信息发布到MQ上
3 放弃实时一致性,进程定时同数据库同步
如果业务侧可以忍受短暂的不一致,那么可以使用最终一致性的方案,上面两个方案可以做成最终一致性也可以做成强一致性,但这一方案肯定是最终一致的

本文介绍了进程内缓存的概念,如带锁的Map和level级别的db,强调其加速数据访问和节省内网带宽的优势。同时讨论了缓存一致性问题及其解决方案,包括单节点通知、使用MQ解耦和定时同步数据库。最后,指出进程内缓存适用于只读数据、高并发场景,并提示在大多数情况下选择缓存集群更为合适。
最低0.47元/天 解锁文章
1458

被折叠的 条评论
为什么被折叠?



