【成为架构师3-14】缓存:进程内缓存该怎么玩

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

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

系列文章是博主对沈剑的《架构师训练营》分享内容的个人笔记总结,原内容公众号“成为架构师”。

什么是进程内缓存

例如:

  1. 带锁的Map
  2. level级别的db
具有的优势

与没有缓存的比较:

  1. 有了进程缓存可以加速数据访问,不用查询数据库

与缓存集群比较

  1. 节省内网带宽
  2. 时延更低
进程内缓存的缺陷和解决方法

最严重的问题:缓存一致性问题

数据的冗余必然造成一致性问题,而进程内缓存是每一个进程一份缓存,不同缓存之间会有一致性问题

解决方案主要有三个:

1 单节点通知

当一个进程内的缓存数据修改的时候它就向它的兄弟节点广播修改的信息,通知它们与它修改的内容的同步
在这里插入图片描述
缺点:

  1. 各节点紧耦合
  2. 实现复杂,进程要关注本身不需要关注的内容
  3. 通信量大

2 使用MQ解耦在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值