| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> 10、Redis的删除动作 -> 正文阅读 |
|
[大数据]10、Redis的删除动作 |
1、redis过期键的删除策略 ? 如果一个键是过期的,那它到了过期时间之后是不是马上就从内存中被被删除呢?? 如果回答yes,立即删除,你自己走还是面试官送你? 如果不是,那过期后到底什么时候被删除呢??是个什么操作? 2、三种不同的删除策略 2.1、立即删除 Redis不可能时时刻刻遍历所有被设置了生存时间的key,来检测数据是否已经到达过期时间,然后对它进行删除。 立即删除能保证内存中数据的最大新鲜度,因为它保证过期键值会在过期后马上被删除,其所占用的内存也会随之 释放。但是立即删除对cpu是最不友好的。因为删除操作会占用cpu的时间,如果刚好碰上了cpu很忙的时候,比如 正在做交集或排序等计算的时候,就会给cpu造成额外的压力,让CPU心累,时时需要删除,忙死。。。。。。。 这会产生大量的性能消耗,同时也会影响数据的读取操作。 总结:对CPU不友好,用处理器性能换取存储空间(拿时间换空间) 2.2、惰性删除 数据到达过期时间,不做处理。等下次访问该数据时, 如果未过期,返回数据 发现已过期,删除,返回不存在。 惰性删除策略的缺点是,它对内存是最不友好的。 如果一个键已经过期,而这个键又仍然保留在redis中,那么只要这个过期键不被删除,它所占用的内存就不会释放。 在使用惰性删除策略时,如果数据库中有非常多的过期键,而这些过期键又恰好没有被访问到的话,那么它们也许永远也不会被删除 (除非用户手动执行FLUSHDB),我们甚至可以将这种情况看作是一种内存泄漏-无用的垃圾数据占用了大量的内存,而服务器却不会自己去释放它们,这对于运行状态非常依赖于内存的 Redis服务器来说肯定不是一个好消息 总结:对 memory不友好,用存储空间换取处理器性能(拿空间换时间) 2.3、上面两种方案都走极端 定期删除 定期删除策略是前两种策略的折中: 定期删除策略每隔一段时间执行一次删除过期键操作,并通过限制删除操作执行的时长和频率来减少删除操作对CPU时间的影响。 周期性轮询 redis库中的时效性数据,采用随机抽取的策略,利用过期数据占比的方式控制删除频度 特点1:CPU性能占用设置有峰值,检测频度可自定义设置 特点2:内存压力不是很大,长期占用内存的冷数据会被持续清理 总结:周期性抽查存储空间(随机抽查,重点抽查) 举例: redis默认每隔100ms检查,是否有过期的key,有过期key则删除。注意: redis不是每隔100ms将所有的key检查一次而是随机 抽取进行检查(如果每隔100ms,全部key进行检查, redis直接进去ICU)。因此,如果只采用定期删除策略,会导致很多key到时 间没有删除。 定期删除策略的难点是确定删除操作执行的时长和频率:如果删除操作执行得太频繁,或者执行的时间太长,定期删除策略就会退化成立即删除策略,以至于将CPU时间过多地消耗在删除过期键上面。如果删除操作执行得太少,或者执行的时间太短,定期删除策略又会和惰性删除策略一样,出现浪费内存的情况。因此,如果采用定期删除策略的话,服务器必须根据情况,合理地设置删除操作的执行时长和执行频率 定期抽样key,判断是否过期 漏网之鱼 3、上述步骤都过堂了,还有漏洞吗? 1定期删除时,从来没有被抽查到 2惰性删除时,也从来没有被点中使用过 上述2步骤===>大量过期的key堆积在内存中,导致 redis内存空间紧张或者很快耗尽 必须要有一个更好的兜底方案。。。。 4、redis缓存淘汰策略登场 4.1、有哪些(redis6.0.8版本)
总结 2个维度 ①过期键中筛选 ②所有键中筛选 4个方面 ①lru 最近最少使用 ②lfu 使用频率最少 ③random 随机 ④ttl 设置了过期时间的 如何配置 redis 的内存淘汰策略? 1.通过修改文件配置(永久生效):配置?maxmemory-policy?字段 2.通过命令修改(重启失效):config set maxmemory-policy allkeys-lru?命令设置内存淘汰策略,config get maxmemory-policy?命令获取当前采用的内存淘汰策略 4.2、你平时用哪一种
4.3、如何配置、修改 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/16 12:47:27- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |