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()

 最后的输出是这样的:

猜你喜欢

转载自www.cnblogs.com/wenha/p/11894413.html