【虹科干货】Redis 开发者需要了解的缓存驱逐策略

这篇具有很好参考价值的文章主要介绍了【虹科干货】Redis 开发者需要了解的缓存驱逐策略。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在你搭建并配置了一个Redis数据库之后Redis成功地提升了应用程序性能。然而这里有一个潜在问题,随着缓存数据的快速增加和内存占用率的逐渐上升,很快会发现Redis缓存容量即将达到硬件存储容量上限。或许你曾听说过缓存驱逐来解决这个问题,但究竟是怎么一回事呢?

无论你是在新兴企业中担任开发人员,还是在大型企业中担任系统管理员,了解缓存驱逐策略,并了解何时以及如何使用,都至关重要。在本文中,我们将深入探讨这些细节,让你对缓存驱逐有更清晰的认识。

一、对缓存驱逐的理解

Redis或任何依赖缓存的系统中,缓存驱逐策略都至关重要。它是解决缓存空间大小和内存占用问题的关键。当缓存数据达到硬件容量上限时,缓存系统必须做出决策:是拒绝接收新的数据,还是通过丢弃旧的数据为新数据腾出空间?

此时,缓存驱逐就发挥作用了。为了保持最佳性能和数据一致性,在缓存达到上限时,缓存系统需要进行一系列判断,以确定应该保留哪些缓存数据,或者需要丢弃哪些缓存数据。

缓存驱逐是指从缓存中删除特定数据的过程。当缓存达到硬件最大存储容量时,必须删除一些数据,为新数据腾出空间。

二、缓存驱逐策略

缓存驱逐策略是一种协议,它解决的问题是当缓存达到上限时,缓存系统需要如何应对。不同的策略对应不同的程序来实现,用于确定应该驱逐(即删除)哪些旧数据。以下是一些常见的策略。

  • 最近最少使用(Least Recently Used, LRU):想象一下,您正在整理衣柜,您会优先扔掉哪些物品?是学生时代遗留的格子衬衫,还是近期购入的一顶鸭舌帽?LRU缓存驱逐策略会首先删除近期被访问次数最少的缓存数据。其基本假设是不经常被访问的数据在短期内不会再次被访问。
  • 最不频繁使用(Least Frequently Used, LFU):假设你是一名图书管理员,你将如何选择要从图书馆书架上移除的书籍?很可能是那些被借阅次数最少的书籍,这也是LFU缓存驱逐策略的思想。LFU策略会优先驱逐最不经常被访问的缓存数据,其基本假设是近期不再需要这些项目。
  • Window TinyLFU(W-TinyLFU):这个策略稍微复杂一些。想象一下,你是一名电台DJ,你希望播放那些受欢迎且最近热门的歌曲。W-TinyLFU缓存驱逐策略根据数据的新旧程度和访问频率判断数据的价值,从而将最有价值的数据保留在缓存中。W-TinyLFU在处理多变的访问模式和分布式缓存环境时尤为有效。
  • 生存时间(Time to Live, TTL):想象一下,冰箱里有一盒新鲜的圣女果,如果在冰箱里放太久,就会开始变质。此时,不管你有多喜欢它们,都应该将它们扔掉。TTL在缓存中有类似的概念。每个缓存数据都有一个特定的“过期时间”。一旦达到该时间限制,无论访问频率或最近访问次数如何,数据都会被驱逐。这种策略可以确保过时的数据被及时清除。它适用于需要定期更新数据,并确保缓存不提供旧数据的情况。

策略的有效性取决于具体的使用情况,没有一种策略适用于所有场景。在选择和使用缓存驱逐策略时,需要仔细考虑应用程序的特定需求和数据访问模式。

三、采用默认设置的风险

Redis中,默认的驱逐策略是易失性LRU(volatile-LRU)。但仅仅依赖默认策略而不了解其潜在影响,就可能存在一定风险。应用程序服务于多样化的用户需求,数据模式和数据驱逐要求可能存在巨大差异。通过正确设置驱逐策略可以预防潜在的问题。

1、第一道防线:监控

首先,我们需要监控缓存性能以确认何时需要进行驱逐操作。我们通过监控工具达成这一目的。

Redis中,可以通过INFO命令来监控缓存性能,也可以使用第三方监控工具提供更详细的性能分析。

优化缓存性能涉及两个方面,需要根据监控性能时所发现的信息,对缓存设置和缓存驱逐策略进行调整。分布式缓存场景中,监控与调优在确保跨多节点一致、缓存的高效管理时尤为重要。

2、选择合适的Redis驱逐策略

Redis中,缓存由maxmemory配置指令进行管理,该指令用于设置内存限制。而maxmemory-policy配置指令则根据所选择的缓存驱逐策略来指导Redis进行驱逐决策。这些配置项都存储在redis.conf配置文件中。

Redis提供了多种驱逐策略,但以下几种可能是你最关心的策略。

(1) allkeys-lru

Redis的allkeys-lru策略用于删除最近最少使用的缓存数据,且无论是否设置了过期时间。

  • 这个策略中,Redis会额外记录每个键的最后访问时间。每次读取或写入键时,Redis会更新这个信息。
  • Redis达到内存限制并且需要驱逐数据时,它会寻找最长时间未被访问的键,也就是"最近最少使用"的键。
  • 接着,Redis会删除这些键,为新的数据腾出可用的空间。

allkeys-lru策略适用于Redis数据库中的所有键,无论是否设置了过期时间。与volatile-lru策略不同的是,后者仅适用于设置了过期时间的键。

(2) volatile-lru

volatile-lru策略用于删除设置了过期时间的最近最少使用的缓存数据。这个策略适用于那些需要定期刷新数据的场景。

(3) allkeys-lfu

allkeys-lfu策略会删除使用频率最低的键。

  • 在这个策略中,Redis会记录每个键的访问频率。每次读取或写入键时,Redis会更新与键相关联的计数器。
  • Redis达到内存限制时,它会寻找具有最低访问频率的键。
  • 然后,Redis会删除这些键,为新的数据腾出可用的空间。

(4) volatile-lfu

allkeys-lfu类似,volatile-lfu策略仅适用于设置了过期时间的键。且按访问频率评判键的价值,当缓存达到上限时,删除访问频率最低的键。

(5) volatile-ttl

volatile-ttl策略优先删除具有最短TTL的键。

  • 这个策略中,Redis会记录每个键的TTL,即键的生存时间。TTL是一个持续时间,在到期之后,键将自动删除。
  • Redis达到内存限制时,它会寻找具有最短TTL的键,也就是即将过期的键。
  • Redis会删除这些键,为新的数据腾出可用的空间。

(6) noeviction

顾名思义,noeviction策略是当Redis达到内存限制并收到写入命令时,不会驱逐任何键,而是返回错误。

  • Redis达到内存限制并且收到写入命令时,它会检查驱逐策略。
  • 如果策略设置为noeviction,则Redis不会驱逐任何键,而是向写入命令返回错误。
  • 在这种情况下,应用程序代码需要确定如何处理该错误条件。

 

事实上,以上每种策略都有其优缺点,最适合的策略需要依具体业务需求而定

当处理大量数据时,使用良好结构的缓存,并结合适当的缓存驱逐策略,可以更好地保持缓存的性能。Redis以其丰富的功能成为优秀的缓存解决方案,并为处理大型数据集的应用程序提供了强大的支持。有效的缓存管理不仅能通过缓存命中加快数据检索,还能减轻缓存未命中的影响,使得Redis成为各种用例中可靠且高效的缓存解决方案。

 文章来源地址https://www.toymoban.com/news/detail-711047.html

到了这里,关于【虹科干货】Redis 开发者需要了解的缓存驱逐策略的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 业务需要咨询?开发遇到 bug 想反馈?开发者在线提单功能上线!

    大家是否遇到过下列问题—— 在开发的时候,遇到 bug 需要反馈… 有合作意向的时候,想更多了解业务和相关产品… 在接入的时候,需要得到专业技术支持… 别急,荣耀开发者服务平台在线提单功能上线了~ 处理问题分类说明:业务咨询、产品咨询、技术支持、问题 BUG 反馈

    2024年02月10日
    浏览(31)
  • 参加微软学生开发者峰会,了解Azure和GitHub……

    #微软学生开发者峰会#  #开源#  #创业# @MicrosoftReactor 首先感谢微软官方能给我提供一次参与学习挑战赛的机会!         这次学生开发者峰会学习挑战赛主要让我学习到了一些Azure云计算平台以及GitHub的一些相关知识,以及对掌握的知识又进行了一次检测。         

    2024年01月25日
    浏览(35)
  • 掘金AIGC时代,开发者更需要什么样的大模型?

      当前,火热的AI大模型领域需要一些冷思考。 自去年年底ChatGPT掀起一轮AIGC热潮以来,国内科技企业扎堆发布大模型和类ChatGPT产品。截止2023年4月,已公开宣布发布或即将发布AI大模型的企业达数十家。多模态大模型的能力不断迭代,市场竞争加剧,同时监管意见及时出台,

    2024年02月09日
    浏览(33)
  • 【干货】Android系统定制基础篇:第二部分(Launcher3支持键盘切换焦点、开发者模式密码确认、禁止非预装应用安装、配置时间)

    Android Launcher3 默认并不支持键盘操作,无法切换焦点,在一些需要支持键盘或遥控操作的设备中无法使用,因些对 Launcher3 做简单修改,使其支持键盘切换焦点。 在安全性要求比较高的产品中,一般会默认关闭『adb调试』,同时禁止用户打开『adb调试』功能。在Android8.1中默认

    2024年02月10日
    浏览(35)
  • Redis详解:.NET Core开发者的面试与应用指南

    本指南为.NET Core开发者提供了Redis的全面解析,包括其作为内存数据库的优势、数据类型、持久化策略、高可用性架构等。同时,介绍了如何使用StackExchange.Redis、FreeRedis和NewLife.Redis等.NET客户端库进行Redis操作,并提供了面试中可能遇到的Redis相关问题的解答,是.NET Core开发者和求职者的宝贵资源。

    2024年04月08日
    浏览(35)
  • 无ios开发者账号如何打包自己的ios 版本app(需要有苹果手机或者mac电脑)

    1.注册苹果账号 https://developer.apple.com/account 2.登录开发者中心 出现协议弹框 同意即可 3.下载Appuploader http://www.applicationloader.net/ 4.打开压缩包内exe文件 5.登录刚刚申请的苹果账号 ,要选未支付688(正式的开发者账号每年要支付688) 6.进入证书管理 7.进入证书管理,创建证书,

    2024年02月09日
    浏览(37)
  • mac升级Monterey12.6之后出现 git命令需要使用命令行开发者工具 安装选项的问题处理

    今天刚升级了最新的系统,升级后发现idea、webstorm等等需要git的全部无法使用了,总是弹出git命令需要使用命令行开发工具,提示让我安装,故以为是版本升级原因,那就安装吧,安装之后打开idea,又提示要安装,这。。。  好吧我再安装一次,然后我修改项目代码后,准备

    2024年02月11日
    浏览(30)
  • Python速查表;腾讯大佬的AIGC设计应用汇总;这个世界需要10亿开发者;67个最常用AI工具清单 | ShowMeAI日报

    👀 日报周刊合集 | 🎡 生产力工具与行业应用大全 | 🧡 点赞关注评论拜托啦! 随着AIGC浪潮的兴起,越来越多小伙伴尝试着使用 GPT 类工具开发小程序、网页、小游戏等应用,也意识到 Python 编程是绕不过去知识门槛。 推荐一份 ShowMeAI 制作的 Pyhton 速查表,涵盖了 Python 3 编

    2024年02月06日
    浏览(40)
  • 【虹科干货】谈谈Redis Enterprise实时搜索的过人之处

    我们都知道,用户在使用应用程序时候,对于速度有着越来越高的要求,真可谓是 “一秒也等不及”。而开发团队又该怎样来满足这种对于实时性的期望呢?   文章速览:   Redis Enterprise 实时搜索的应用场景 利用索引为开发人员带来更好的体验 Redis Enterprise 实时搜索的优势

    2024年02月08日
    浏览(29)
  • 【虹科干货】Redis企业版给DevOps团队带来了哪些价值?

    内存太贵?现代化转型太难?还在花费精力维护数据库基础设施?Redis Enterprise 在开源版的基础上增加了一整套包含管理、自动化、弹性以及安全等方面的功能,使其更适合企业级的应用场景。那么, Redis Enterprise 如何能成为为您节约成本的选择?   文章速览: 发现 1:为应

    2024年02月06日
    浏览(24)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包