首页 > 编程语言 > 详细

python redis 批量设置过期key

时间:2019-11-24 16:04:04      阅读:124      评论:0      收藏:0      [点我收藏+]

在使用 Redis、Codis 时,我们经常需要做一些批量操作,通过连接数据库批量对 key 进行操作:

  关于未过期:

    1.常有大批量的key未设置过期,导致内存一直暴增

    2.rd需求 扫描出这些key,rd自己处理过期(一般dba不介入数据的修改)

    3.dba 批量设置过期时间,(一般测试可以直接批量设置,线上谨慎操作)

  通过一段代码,批量实现给未设置过期的key,设置24小时过期

 

 1 from redis import Redis
 2 def setExpiredKeys():
 3     try:
 4         if redis_pass == none:
 5             redisclient = Redis(host=redis_host, port=redis_port,db=0)
 6         else:
 7             redisclient = Redis(host=redis_host, port=redis_port, password=redis_pass)
 8         for key in redisclient.scan_iter(count=500):
 9             keyttl = redisclient.execute_command(ttl, key)
10             if keyttl == -1: # 此处扫到key,可以进行导出处理或者执行命令
11                 redisclient.expire(key, 86400)
12     except Exception as e:
13         raise e
14 if __name__ == __main__:
15     redis_host = 192.168.0.1
16     redis_port = 6379
17     redis_pass = 123456
18     setExpiredKeys()
代码功能:
通过导入redis模块中的Redis类函数,访问redis数据;建立Redisclient客户端,通过scan_iter 每次获取500个key;对key执行 ttl 命令,通过返回值判断key是否设置了过期,如果没有设置,就通过 expire 命令 批量设置过期时间
 

python redis 批量设置过期key

原文:https://www.cnblogs.com/cuisi/p/11922426.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!