redis内存上限的处理策略

发布时间:2024年01月19日

?一、前言

? ? ??在 Redis 中,maxmemory 是一个用于设置 Redis 内存使用的上限的配置项。当 Redis 的内存占用达到 maxmemory 时,需要采取一些策略来处理新写入的数据以及对现有数据的读取和删除。这些策略可以通过配置 maxmemory-policy 来指定

二、策略

?volatile-lru: 从已设置过期时间的键中挑选最近最少使用的键进行删除。这个策略主要用于删除具有过期时间的键,以腾出空间

allkeys-lru: 从所有键中挑选最近最少使用的键进行删除。不考虑键是否设置了过期时间,对所有键都适用

volatile-random: 从已设置过期时间的键中随机选择一个进行删除。同样,这个策略也主要用于处理带有过期时间的键

allkeys-random: 从所有键中随机选择一个进行删除。与 volatile-random 类似,不考虑键是否设置了过期时间

volatile-ttl: 从已设置过期时间的键中挑选将要过期的键进行删除。删除的是即将到期的键,以腾出空间

noeviction: 不删除任何键,当达到 maxmemory 时,新写入的操作会得到错误响应。这种策略适用于确保 Redis 不会删除任何数据,而是拒绝写入以确保数据完整性的场景

volatile-lfu: 从已设置过期时间的键中挑选最少使用的键进行删除。与 LRU 类似,但基于键的访问频率(LFU 算法)

allkeys-lfu: 从所有键中挑选最少使用的键进行删除。考虑所有键的访问频率,不考虑是否设置了过期时间

可以根据开发人员的要求选择适合的策略,以下是在redis配置文件夹中的使用示例

maxmemory 3G                #建议设置为最大内存的四分之三
maxmemory-policy volatile-lru      #配置清理策略

如果在 Redis 中达到 maxmemory 而没有配置任何删除策略 (maxmemory-policy 未配置或配置为 noeviction),所有新的写入操作(SET、INCR、LPUSH等)将会失败,返回错误信息,指示 Redis 已经达到内存限制。读取操作(GET、LRANGE等)仍然是可以执行的,因为这些操作不会导致额外的内存占用

文章来源:https://blog.csdn.net/ApexPredator/article/details/135693074
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。