面试—如何介绍项目中的多级缓存?

项目中使用的多级缓存也就是 分布式缓存 Redis + 本地缓存 Caffeine,那么令 Caffeine 作为一级缓存,Redis 作为二级缓存,在项目中通过记录数据的访问次数,将热点数据放在 本地缓存,将非热点数据放在 Redis缓存 中,访问流程如下:

使用多级缓存的好处在于 Redis 单机每秒可以接收 10w 次的请求,本地缓存比 Redis 缓存可以抗更高数量级的并发,本地缓存可以每秒接收百万的请求,使用两级缓存极大增加访问效率

但是使用多级缓存之后,存在数据一致性问题

  • Redis 缓存和 MySQL 数据不一致:可以使用 延时双删 来保证数据的一致性,如果需要更准确的数据一致性,可以使用 Canal 来监听 MySQL 的 binlog 日志来保证数据的一致性

  • 在分布式环境下,多台应用之间本地缓存以及和 MySQL 之间的数据不一致:可以通过 MQ 来保证数据一致性

    当应用 1 收到请求更新数据库,同时应用 1 更新本地缓存,并且发送更新 MQ 广播消息,让其他的应用也更新本地缓存

如何对热点数据进行存储?

其实就是将数据的访问次数记录起来,当发现访问量非常大,在本地记录一下,可以使用 HashMap 进行存储,记录一下热点数据,再通知所有的服务将热点数据放入到本地缓存中来

相关推荐
SPC的存折4 小时前
1、Redis数据库基础
linux·运维·服务器·数据库·redis·缓存
迷茫的启明星6 小时前
各职业在当前发展阶段,使用AI的舒适区与盲区
大数据·人工智能·职场和发展
身如柳絮随风扬11 小时前
Redis如何实现高效插入大量数据
数据库·redis·缓存
挖稀泥的工人11 小时前
AI聊天界面的布局细节和打字跟随方法
前端·javascript·面试
予早11 小时前
Redis 设置库的数量
数据库·redis·缓存
黑金IT12 小时前
vLLM本地缓存实战,重复提交直接复用不浪费算力
人工智能·缓存
张元清13 小时前
5 分钟用 Vite SSR 搭建一个全栈 React 应用
前端·javascript·面试
却话巴山夜雨时i13 小时前
互联网大厂Java面试实录:技术栈解析与场景剖析
java·大数据·spring boot·spring cloud·微服务·ai·面试
嘻嘻哈哈樱桃13 小时前
俄罗斯套娃信封问题力扣--354
算法·leetcode·职场和发展
田梓燊13 小时前
2026/4/12 leetcode 1320
算法·leetcode·职场和发展