#青训营笔记创作活动#

2月11日 打卡day30

今日学习: 缓存

- 本地缓存
基于接口维度, 在内存中做短期缓存
java中的框架有 Ehcache, Guava Cache, Caffeine Cache
会出现缓存漂移(多次刷新内容, 命中到不同后台服务后, 响应不一致)
- 集中式缓存
redis集群, 可以实现跨机器的缓存, 并且方便的进行扩容

- 缓存一致性
- 先更新缓存, 在更新数据库
- 先更新数据库, 再更新缓存
- 先删除缓存, 在更新数据库
- 先更新数据库, 再删除缓存
低并发的场景下可以利用数据库的事务特性, 将更新缓存与更新数据库放到同一事务中, 如果更新缓存失败则同步回滚
高并发场景下可以结合`重试`+`mq异步补偿`的方式更新缓存, 保证数据的最终一致性

[聊一聊作为高并发系统基石之一的缓存,会用很简单,用好才是技术活 - 掘金 (juejin.cn)](juejin.cn)
展开
评论