zoukankan      html  css  js  c++  java
  • python redis 批量设置过期key

    在使用 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 命令 批量设置过期时间
     
  • 相关阅读:
    Day10
    Python pyspider 安装与开发
    深入理解ES6之《块级作用域绑定》
    深入理解ES6之《扩展对象》
    这些特效对于学习前端我们很有用
    算法之旅 | 选择排序法
    JavaScript读取剪贴板中的表格生成图片
    深入理解ES6之《ES7》
    深入理解ES6之《用模块封装代码》
    php://input,$_POST,$HTTP_RAW_POST_DATA区别
  • 原文地址:https://www.cnblogs.com/cuisi/p/11922426.html
Copyright © 2011-2022 走看看