• Python查询Redis中的Key


    今日,大哥让我查下项目的在线用户量,听到这个消息顿时懵逼了,在线用户量,这个该怎么查????想到项目中的登陆用户缓存信息Token都存放在Redis中,是不是可以根据Redis中Token的个数大致估出来项目的在线用户量,用户登录是有有效期的(七小时有效、三天免登陆等),因此,我们可以根据Redis中Key值的有效期来大致归纳用户的时段在线量,话不多说,上代码:

     1 # 添加redis模块引用
     2 import redis
     3 
     4 
     5 def search_key():
     6     
     7     # 创建Redis连接池
     8     # host:连接主机
     9     # port:端口号,默认6379
    10     # db:数据库,默认0-15
    11     pool = redis.ConnectionPool(host='localhost', port=6379, db=14)
    12    
    13     # 从连接池中获取一个连接
    14     r = redis.StrictRedis(connection_pool=pool)
    15 
    16     # 获取redis中keys的个数,我在redis的这个库里只存放用户的登陆token信息,不存放别的信息,不需要筛选
    17     # 如果redis库中还存放着其他信息,需要在此筛选,
    18     keys = r.keys()
    19     # print(keys)
    20     print('Token的总个数:', len(keys))
    21     twoHours = 0
    22     threeHours = 0
    23     fiveHours = 0
    24     for i in range(len(keys)):
    25         key = keys[i]
    26         remainTime = r.ttl(key)
    27         if remainTime > 7200:
    28             twoHours = twoHours + 1
    29         if remainTime > 10800:
    30             threeHours = threeHours + 1
    31         if remainTime > 18000:
    32             fiveHours = fiveHours + 1
    33 
    34         print('超过两个小时有效:' + str(twoHours))
    35         print('超过三个小时有效:' + str(threeHours))
    36         print('超过五个小时有效:' + str(fiveHours))
    37 
    38 
    39 if __name__ == '__main__':
    40     search_key()

     最后的输出是这样的:

  • 相关阅读:
    毕业半年,码过5个城市
    Java实现office文档与pdf文档的在线预览功能
    挺过最艰难的2018,我终将长大
    dubbo源码分析(一)-从xml到我们认识的Java对象
    沉淀一年,我想推荐这些书给你
    Java动态代理(一)
    Java工程师成神之路思维导图
    Java
    阿里巴巴Java开发手册思维导图
    Mysql的排他锁和共享锁
  • 原文地址:https://www.cnblogs.com/wenha/p/11894413.html
Copyright © 2020-2023  润新知