标签:访问 过期 exp 使用 imp none main red 建立
在使用 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()
标签:访问 过期 exp 使用 imp none main red 建立
原文地址:https://www.cnblogs.com/cuisi/p/11922426.html