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

 # 添加redis模块引用
import redis def search_key(): # 创建Redis连接池
# host:连接主机
# port:端口号,默认6379
# db:数据库,默认0-15
pool = redis.ConnectionPool(host='localhost', port=6379, db=14) # 从连接池中获取一个连接
r = redis.StrictRedis(connection_pool=pool) # 获取redis中keys的个数,我在redis的这个库里只存放用户的登陆token信息,不存放别的信息,不需要筛选
# 如果redis库中还存放着其他信息,需要在此筛选,
keys = r.keys()
# print(keys)
print('Token的总个数:', len(keys))
twoHours = 0
threeHours = 0
fiveHours = 0
for i in range(len(keys)):
key = keys[i]
remainTime = r.ttl(key)
if remainTime > 7200:
twoHours = twoHours + 1
if remainTime > 10800:
threeHours = threeHours + 1
if remainTime > 18000:
fiveHours = fiveHours + 1 print('超过两个小时有效:' + str(twoHours))
print('超过三个小时有效:' + str(threeHours))
print('超过五个小时有效:' + str(fiveHours)) if __name__ == '__main__':
search_key()

最后的输出是这样的:

Python查询Redis中的Key-LMLPHP

05-01 01:00