曾经设置过有效期的数据,到达了有效期,却没有被删除的数据
这四个指令可以设置过期时间,会给一个key设置对应的过期时间
内部是这样存储的
左边0x0110是内存地址
右边则是过期时间
一个value对应一个field 是hash的结构
数据删除策略的目标
在内存占用与CPU占用之间寻找一种平衡,顾此失彼都会造成整体redis性能的下降,甚至引发服务器宕机或内存泄露
expirelfNeeded()
这个函数检查数据是否过期
127.0.0.1:6379> info server configured_hz:10
每秒钟执行server.hz次serverCron()
serverCron()是轮询
databasesCron()
对每个库进行轮询
activeExpireCycle()
activeExpireCycle()
对每个expires[*]逐一进行检测,每次执行250ms/server.hz
对某个expires[*]检测时,随机挑选W个key检测
参数current_db用于记录activeExpireCycle()
进入哪个expires[*] 执行
如果activeExpireCycle()
执行时间到期,下次从current_db继续向下执行
策略 | 对内存 | 对cpu | 总结 |
---|---|---|---|
定时删除 | 节约内存,无占用 | 不分时段占用CPU资源,频度高 | 拿时间换空间 |
惰性删除 | 内存占用严重 | 延时执行,CPU利用率高 | 拿空间换时间 |
定期删除 | 内存定期随机清理 | 每秒花费固定的CPU资源维护内存 | 随机抽查,重点抽查 |
当新数据进入redis时,如果内存不足怎么办?
freeMemoryIfNeeded()
检测内存是否充足。如果内存不满足新加入数据的最低存储要求,redis要临时删除一些数据为当前指令清理存储空间。清理数据的策略称为逐出算法。最大可使用内存
maxmemory
每次选取待删除数据的个数
maxmemory-samples
删除策略
maxmemory-policy
检测易失数据(可能会过期的数据集server.db[i].expires )
① volatile-lru:挑选最近最少使用的数据淘汰
② volatile-lfu:挑选最近使用次数最少的数据淘汰
③ volatile-ttl:挑选将要过期的数据淘汰
④ volatile-random:任意选择数据淘汰
检测全库数据(所有数据集server.db[i].dict )
⑤ allkeys-lru:挑选最近最少使用的数据淘汰
⑥ allkeys-lfu:挑选最近使用次数最少的数据淘汰
⑦ allkeys-random:任意选择数据淘汰
放弃数据驱逐
⑧ no-enviction(驱逐):禁止驱逐数据(redis4.0中默认策略),会引发错误OOM(Out Of Memory 内存溢出)
在配置文件中
maxmemory-policy volatile-lru
数据逐出策略配置依据
通过info查看下面两个值 127.0.0.1:6379> info keyspace_hits:24 # 命中空间 keyspace_misses:0 # 命中丢失