redis过期策略

一、redis的key有六种过期策略

1、noeviction:一旦内存满则返回错误

2、allkeys-lru:对所有的key进行LRU

3、volatile-lru:只对设置了过期的key进行LRU(默认的方式)

4、allkeys-random:随机剔除一个key

5、volatile-random:对设置过期的key进行随机剔除一个

6、volatile-ttl:删除即将过期的key

根据官网的描述,redis使用的LRU并非真正的LRU算法,精确度并不高。redis3.0版本的LRU会维持一个候选池,性能会更加好。

二、一些内存和过期策略的设置和查看

1、设置实例的内存大小(本地执行可以不用-h $host,单位是B)

redis-cli -h $host -p $port config set maxmemory 1024

2、获取实例的内存大小

redis-cli -h $host -p $port config get maxmemory

3、设置过期策略

redis-cli -h $host -p $port config set maxmemory-policy volatile-lru

4、查看过期策略

redis-cli -h $host -p $port config get maxmemory-policy

说明:测试过volatile-lru,确实在满了之后如果有设置了过期时间的key就会执行LRU,可以继续插入。如果没有设置了过期时间的key了就会报错

时间: 2024-12-29 10:01:51

redis过期策略的相关文章

第九章 Redis过期策略

注:本文主要参考自<Redis设计与实现> 1.设置过期时间 expire key time(以秒为单位)--这是最常用的方式 setex(String key, int seconds, String value)--字符串独有的方式 具体的使用方式:查看"java企业项目开发实践"的XXXXXXXXXXXXXXXXXXXXXX 注意: 除了字符串自己独有设置过期时间的方法外,其他方法都需要依靠expire方法来设置时间 如果没有设置时间,那缓存就是永不过期 如果设置了过

redis过期策略设置

中6中过期策略的具体方式. redis 中的默认的过期策略是volatile-lru .设置方式 可以通过命令直接设置 config set maxmemory-policy volatile-lru maxmemory-policy 六种方式 volatile-lru:只对设置了过期时间的key进行LRU(默认值) allkeys-lru : 删除lru算法的key volatile-random:随机删除即将过期key allkeys-random:随机删除 volatile-ttl : 删

Redis过期策略及实现原理

我们在使用redis时,一般会设置一个过期时间,当然也有不设置过期时间的,也就是永久不过期. 当我们设置了过期时间,redis是如何判断是否过期,以及根据什么策略来进行删除的. redis设置过期时间:expire key time(以秒为单位)–这是最常用的方式setex(String key, int seconds, String value)–字符串独有的方式注: 除了字符串自己独有设置过期时间的方法外,其他方法都需要依靠expire方法来设置时间 如果没有设置时间,那缓存就是永不过期

redis过期策略和内存淘汰机制

目录 常见的删除策略 redis使用的过期策略:定期删除+惰性删除 定期删除 惰性删除 为什么要采用定期删除+惰性删除2种策略呢? redis内存淘汰机制 常见的删除策略 1.定时删除:在设置键的过期时间的同时,创建一个timer,让定时器在键的过期时间到达时,立即执行对键的删除操作.(主动删除) 对内存友好,但是对cpu时间不友好,有较多过期键的而情况下,删除过期键会占用相当一部分cpu时间. 2.惰性删除:放任过期键不管,但是每次从键空间中获取键时,都检查取到的键是否过去,如果过期就删除,如

Redis系列(三)--过期策略

制定Redis过期策略,是整个Redis缓存策略的关键之一,因为内存来说,公司不可能无限大,所以就要对key进行一系列的管控. 文章结构:(1)理解Redis过期设置API(命令与Java描述版本):(2)理解Redis内部的过期策略:(3)对开发需求而言,Redis过期策略的设计实现经验. 本系列文章: (1)Redis系列(一)–安装.helloworld以及读懂配置文件 (2)Redis系列(二)–缓存设计(整表缓存以及排行榜缓存方案实现) 一.理解Redis过期设置API(命令与Java

redis 的过期策略都有哪些?内存淘汰机制都有哪些?

redis 过期策略 redis 过期策略是:定期删除+惰性删除. 所谓定期删除,指的是 redis 默认是每隔 100ms 就随机抽取一些设置了过期时间的 key,检查其是否过期,如果过期就删除. 假设 redis 里放了 10w 个 key,都设置了过期时间,你每隔几百毫秒,就检查 10w 个 key,那 redis 基本上就死了,cpu 负载会很高的,消耗在你的检查过期 key 上了.注意,这里可不是每隔 100ms 就遍历所有的设置过期时间的 key,那样就是一场性能上的灾难.实际上 r

4.redis 的过期策略都有哪些?内存淘汰机制都有哪些?手写一下 LRU 代码实现?

作者:中华石杉 面试题 redis 的过期策略都有哪些?内存淘汰机制都有哪些?手写一下 LRU 代码实现? 面试官心理分析 如果你连这个问题都不知道,上来就懵了,回答不出来,那线上你写代码的时候,想当然的认为写进 redis 的数据就一定会存在,后面导致系统各种 bug,谁来负责? 常见的有两个问题: 往 redis 写入的数据怎么没了? 可能有同学会遇到,在生产环境的 redis 经常会丢掉一些数据,写进去了,过一会儿可能就没了.我的天,同学,你问这个问题就说明 redis 你就没用对啊.re

【redis】关于Redis数据过期策略

1.Redis中key的的过期时间 通过EXPIRE key seconds命令来设置数据的过期时间.返回1表明设置成功,返回0表明key不存在或者不能成功设置过期时间.在key上设置了过期时间后key将在指定的秒数后被自动删除.被指定了过期时间的key在Redis中被称为是不稳定的. 当key被DEL命令删除或者被SET.GETSET命令重置后与之关联的过期时间会被清除 127.0.0.1:6379> setex s 20 1 OK 127.0.0.1:6379> ttl s (intege

Redis的过期策略

EXPIRE key seconds Available since 1.0.0. Time complexity: O(1) 为指定的KEY设置一个过期时间.当过了过期时间,这个KEY将自动被删除.如果使用DEL命令删除这个KEY或者使用SET命令或者GETSET命令重新设置这个KEY的值.过期时间将会被清除.使用PERSIST将这个KEY转换成持久不过期的KEY,也可以清除过期时间. 如果使用RENAME重新命名一个KEY,这个KEY关联的过期时间将转成新KEY的过期时间. 可以使用EXPI