Redis:代码实战之缓存污染

【关于作者】

关于作者,目前在蚂蚁金服搬砖任职,在支付宝营销投放领域工作了多年,目前在专注于内存数据库相关的应用学习,如果你有任何技术交流或大厂内推及面试咨询,都可以从我的个人博客(https://0522-isniceday.top/)联系我

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kltXyZTm-1681039806327)(https://zhangyuxiangplus.oss-cn-hangzhou.aliyuncs.com/boke/缓存污染.png)]

1.什么是缓存污染

缓存污染指的是缓存中存在很多冷数据或者说查询频次很少的数据,如果这些数据占用的内存过大,会引发缓存的淘汰,会影响其性能

2.如何解决缓存污染

根据缓存的淘汰策略,

  • 按照redis的淘汰策略而言,volatile-random和allkeys-random采取的是随机淘汰,而volatile-ttl则是只能在知道数据多长时间之后不再被访问之后才有效

  • LRU是否能够避免缓存污染?

    LRU:其核心思想是当一个数据刚被访问,那么这个数据一定是热数据,就会很久之后才会淘汰

    但是真的是热数据吗?

    由于只看访问时间,没有查看访问次数,可能会出现扫描单次查询操作时,无法解决缓存污染,如果这个单次扫描的数据量很大,那么这些数据的lru值都会很大,但是这些数据又不会再被访问,则会导致缓存污染

    img

  • Redis 4.0新增的LFU

    LFU会从两个维度淘汰数据:1.数据访问时间 2.数据访问次数

3.LFU缓存策略的优化

LFU在LRU的基础上加了个计数器,淘汰时会现将访问次数较少的数据淘汰,当数据访问次数一致时,再比较访问时间,访问时间小的先淘汰。

详情见Redis学习(十九)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哈哈哈张大侠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值