首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
SAAS
ToB门户
了解全球最新的ToB事件
论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
微博
Follow
记录
Doing
博客
Blog
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
排行榜
Ranklist
相册
Album
应用中心
qidao123.com技术社区-IT企服评测·应用市场
»
论坛
›
数据库
›
分布式数据库
›
当地缓存的三种实现
返回列表
发新帖
当地缓存的三种实现
[复制链接]
发表于 2025-9-7 13:23:23
|
显示全部楼层
|
阅读模式
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
×
当地缓存
当地缓存的实现
常见的当地缓存三种实现
:
使用Java或自定义数据结构构造JVM当地缓存,大多数场景下
ConcurrentHashMap
就可以支持的很好
使用Guava LoadingCache构造当地缓存,支持
配置
加载(LRU最近最少使用算法)
使用Caffeine Cache构造当地缓存,它是对LoadingCache的优化(
TinyLfu
,近似的LFU算法)
Caffeine:
Caffeine 使用的缓存淘汰算法比 Guava 的 LRU 更先辈、更复杂和高效。它基于
Window TinyLfu
。
TinyLfu (Tiny Least Frequently Used):
这是一种近似的 LFU (Least Frequently Used,最不常用) 算法,它通过一个紧凑的数据结构(如 Count-Min Sketch)来
估计
条目标访问频率,即使条目被淘汰后,它的频率信息也能保留一段时间。这使得 TinyLfu 对扫描反抗(scan resistance)有更好的表现,即短暂的大量访问不会轻易冲垮整个缓存。
Window:
Caffeine 将缓存分为一个小的“窗口”地域和一个大的“主”地域。新加入的条目首先辈入窗口,窗口通常使用 LRU 进行管理。
Admission Policy (录取策略):
当窗口中的条目要进入主地域,或者有新条目要替换主地域中的条目时,Caffeine 会使用 TinyLfu 估算的频率信息来决定是否“录取”这个条目进入主地域,以及淘汰主地域中的哪个条目。主地域通常也使用 LRU 或类 LRU 策略进行管理。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
继续阅读请点击广告
回复
使用道具
举报
返回列表
悠扬随风
+ 我要发帖
×
登录参与点评抽奖,加入IT实名职场社区
去登录
微信订阅号
微信服务号
微信客服(加群)
H5
小程序
快速回复
返回顶部
返回列表