时间:2021-05-22
这篇文章主要介绍了python redis 批量设置过期key过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
在使用 Redis、Codis 时,我们经常需要做一些批量操作,通过连接数据库批量对 key 进行操作:
关于未过期:
1.常有大批量的key未设置过期,导致内存一直暴增
2.rd需求 扫描出这些key,rd自己处理过期(一般dba不介入数据的修改)
3.dba 批量设置过期时间,(一般测试可以直接批量设置,线上谨慎操作)
通过一段代码,批量实现给未设置过期的key,设置24小时过期
from redis import Redisdef setExpiredKeys(): try: if redis_pass == 'none': redisclient = Redis(host=redis_host, port=redis_port,db=0) else: redisclient = Redis(host=redis_host, port=redis_port, password=redis_pass) for key in redisclient.scan_iter(count=500): keyttl = redisclient.execute_command('ttl', key) if keyttl == -1: # 此处扫到key,可以进行导出处理或者执行命令 redisclient.expire(key, 86400) except Exception as e: raise eif __name__ == '__main__': redis_host = '192.168.0.1' redis_port = 6379 redis_pass = '123456' setExpiredKeys()代码功能:
通过导入redis模块中的Redis类函数,访问redis数据;建立Redisclient客户端,通过scan_iter 每次获取500个key;对key执行 ttl 命令,通过返回值判断key是否设置了过期,如果没有设置,就通过 expire 命令 批量设置过期时间
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.过期设置Redis中设置过期时间主要通过以下四种方式:expirekeyseconds:设置key在n秒后过期;pexpirekeymilliseconds
Redis中有删除单个Key的指令DEL,但好像没有批量删除Key的指令,不过我们可以借助Linux的xargs指令来完成这个动作。复制代码代码如下:redis
Expire为key设置过期时间Setex为key设置value值,并且,设置过期时间区别Setex是一个原子操作设置值,设置过期时间两个动作,会在同一时间完成
需求有时候因为RedisKey没有设置过期时间或者因为业务需求或者Redis内存不足或者修改RedisKey值等需求,并且这些Key是有规律的,可以通过正则表达
Expire命令用于设置key的过期时间。key过期后将不再可用。r.set('2','4028b2883d3f5a8b013d57228d760a93')#成