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