java redis过期键_Redis 过期键删除策略

Redis 中数据库键的过期时间都保存在过期字典中,当一个键过期了,Redis 存在三种不同的删除策略:定时删除、惰性删除和定期删除

定时删除

定义

在设置键的过期时间的同时创建一个计时器,让定时器在键过期时间来临时,立即执行对键的删除操作。

定时删除策略对内存是最友好的:通过使用定时器,定时删除策略可以保证过期键会尽快被删除,并且释放过期键所占用的内存。

但是另一方面,它对 CPU 时间是嘴不友好的:在过期键比较多的情况下,删除过期键这一行为可能会占用相当一部分的 CPU 时间,在内存不紧张但是 CPU 时间紧张的情况下,将 CPU 时间用在删除和当前任务无关的过期键上,无疑会对服务器的响应时间和吞吐量造成影响。

惰性删除

定义

放任过期键不管,但是每次从键空间中获取键时都检查取得的键是否过期,如果过期的话,就删除该键;如果没有过期则返回该键。

惰性删除策略对 CPU 时间来说是最友好的,但是它对内存是最不友好的:如果一个键已经过期,而这个键又恰好没有被访问到的话,那么它可能永远都不回被删除,甚至可以将这种情况视为一种内存泄漏 —— 无用的垃圾数据占用了大量的内存,而服务器却不能主动去释放它们,这对于运行状态非常依赖于内存的 Redis 服务器来说,并不是一个好消息。

定期删除

定义

每隔一段时间,程序都会对数据库进行一次检查,删除里面的过期键。至于要删除多少过期键,以及要检查多少个数据库,则由算法决定。

从上面对定时删除和惰性删除的讨论来看,这两种删除方式在单一使用时都有非常明显的缺陷,定期删除策略可以看作是两种策略的一种整合和折中:

定期删除策略每隔一段时间执行一次删除过期键操作,并通过限制删除操作执行的时长和频率来减少删除操作对 CPU 时间的影响。

通过定期删除过期键,定期删除策略有效减少了因为过期键而带来的内存浪费

但是定期删除策略的难点是确定删除操作执行的时长和频率:

如果删除操作执行太过频繁,或者执行的时间太长,定期删除策略就会退化成定时删除策略,以至于 CPU 时间过多的消耗在删除过期键上

如果删除操作执行的太少,或者执行的时间太短,定期删除策略又会和惰性删除策略一样,出现浪费内存的情况

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Redis支持模糊查询,可以通过使用通配符来匹配一定范围内的key。 以下是几个常用的通配符: - *:匹配任意数量的字符,包括0个字符 - ?:匹配单个字符 使用通配符进行模糊查询的语法为: ``` KEYS pattern ``` 其中,pattern为匹配模式,可以包含通配符。 例如,要查找所有以foo开头的key,可以使用以下命令: ``` KEYS foo* ``` 要查找所有以bar结尾的key,可以使用以下命令: ``` KEYS *bar ``` 需要注意的是,使用模糊查询会影响Redis的性能,因此应该尽量避免在生产环境中使用。 ### 回答2: Redis是一种高性能的内存数据库,主要用于缓存数据和提供快速的读写操作。在Redis中,可以使用模糊查询来查找符合特定模式的值对。 在Redis中,模糊查询主要使用通配符来匹配的模式。通配符有两种常用的形式: 1. "*"通配符:表示匹配任意数量的字符,包括零个字符。例如,使用"key*"可以匹配以"key"开头的所有,如"key1"、"key2"等。 2. "?"通配符:表示匹配一个字符。例如,使用"key?"可以匹配以"key"开头并且只有一个字符的,如"key1"、"key2"等。 除了通配符,Redis还提供了一些特殊的模式匹配规则: 1. "[abc]":表示匹配括号内的任意一个字符。例如,使用"key[12]"可以匹配"key1"和"key2"。 2. "[^abc]":表示匹配不在括号内的任意一个字符。例如,使用"key[^12]"可以匹配除了"key1"和"key2"之外的。 3. "[a-z]":表示匹配从a到z之间的任意一个字符。 使用Redis的模糊查询可以很方便地查找符合特定模式的值对,并且可以通过设置过期时间来实现缓存功能。但是需要注意的是,由于模糊查询需要遍历所有的值对,所以在大规模数据的情况下,会影响查询的性能,建议做好优化措施。 ### 回答3: Redis模糊查询是指在使用Redis数据库进行查询时,可以使用通配符或正则表达式来匹配模式,从而进行模糊查询。 在Redis中,可以使用通配符进行模糊查询。通配符包括"*"和"?",其中"*"表示任意数量的字符,"?"表示一个字符。通过使用通配符,可以匹配的范围更加广泛,从而实现模糊查询。 另外,Redis还支持使用正则表达式进行模糊查询。正则表达式有更强的灵活性,能够更精确地匹配需要查询的数据。通过使用正则表达式,可以实现更复杂的模糊查询操作。 为了使用Redis的模糊查询功能,需要使用相关的命令和参数。例如,使用KEYS命令可以获取匹配某个模式的所有值对。使用SCAN命令可以遍历所有值对,并根据正则表达式匹配进行过滤。 需要注意的是,在使用Redis进行模糊查询时,由于Redis是单线程的,大规模的模糊查询可能会对性能产生影响。因此,在进行模糊查询的时候,需要根据具体情况选择合适的查询方式,并注意性能优化。 总结来说,Redis模糊查询是一种通过使用通配符或正则表达式来匹配模式的查询方式,能够更灵活地查询需要的数据。在实际使用中,可以结合具体需求选择合适的查询方式,并注意性能优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值