- 淘汰策略相关问题
1)如何保证 Redis 中数据都是热点数据?
比如,现在 MySQL 数据库里有2000万数据,Redis 中只能存20万数据,如何保证 Redis 中的数据都是热点数据呢?
答:在这里就用到了 Redis 的淘汰策略了,首先计算一下 20 万数据大概占用的内存大小,然后设置一下 Redis 的最大内存容量大小,并将淘汰策略为 volatile-lru 或者 allkeys-lru ,Redis 会根据自身数据进行淘汰策略,即淘汰最近最少使用的数据,最后留下来的都是热点数据。
2)Redis 内存满了怎么办?
如果达到设置的上限,默认淘汰策略下,Redis 的写命令会返回错误信息,但是读命令还是可以正常返回。
一般要配置合适的淘汰机制,当 Redis 达到内存上限时会淘汰掉旧的数据。
3)Redis 怎么配置最大内存容量?
单位:字节。若本机自带内存只有1G,一般推荐Redis设置内存为最大物理内存的四分之三,所以设置0.75G,换成byte是751619276. - 淘汰策略
1)Redis 的8种淘汰策略
Redis 4.0 开始支持基于 LFU 算法的淘汰策略。
比如 Redis 中的一个键,之前一直都没有被访问过,最近突然被访问了一次。那么使用 LRU 淘汰策略就很难被淘汰,因为 LRU 会把它定义为热键,会很晚淘汰,而使用 LFU 淘汰策略就可能很快被淘汰,因为 LRU 优先淘汰最近未被使用的,而 LFU 优先淘汰最近访问频率最低的。所以 LFU 比 LRU 淘汰更精确,有助于提升 Redis 的缓存命中率。 - Redis 过期键的删除策略
Redis 过期键的删除策略有 3 种:
1)定时删除
设置键的过期时间时,同时创建一个定时器,当键达到过期时间时,让定时器执行键的删除操作。
2)惰性删除
这种策略不会定时、主动去删除过期的键,每次从键空间获取键时,首先检查该键是否过期,如果过期则主动删除该键,否则直接返回。
3)定期删除
程序每个一段时间会取出一定数量的随机键进行检查,然后删除所有过期的键。
8.Redis 淘汰策略
最新推荐文章于 2024-05-07 14:19:53 发布