Python对Redis进行实时用户数统计


Python对Redis进行实时用户数统计

安装redis
#wget http://redis.googlecode.com/files/redis-2.6.14.tar.gz
#tar xzf redis-2.6.14.tar.gz
#cd redis-2.6.14
#make

执行make的时候报错,具体报错信息如下:
zmalloc.o: In function `zmalloc_used_memory':
/usr/local/redis-2.6.14/src/zmalloc.c:223: undefined reference to `__sync_add_and_fetch_4'
collect2: ld returned 1 exit status
make[1]: *** [redis-server] Error 1
make[1]: Leaving directory `/usr/local/redis-2.6.14/src

在make操作的时候加一个执行参数:makeCFLAGS="-march=i686"
然后就不报错了。
编译的可执行文件在src目录中,启动运行Redis:
# src/redis-server

如图正确启动后,安装redis-py
git clone https://github.com/andymccurdy/redis-py.git
cd redis-py
python setup.py install

python操作在线用户数的简单代码:
#!/usr/bin/python
import redis
r=redis.StrictRedis(host='192.168.39.138',port=6379)
r.set('online','0')
r.incr('online')
r.incr('online')
r.incr('online')
r.decr('online')
print r.get('online')

如果有新的用户登录incr插入一条记录,如果有用户下线可以使用decr或者规定一个超时时间,对不活跃的用户自动删除记录。
#./redis.py
2

模式测试,当前有三个用户登录变为在线,同时一个用户离线,所以显示在线用户为2人,实时性更高。

推荐阅读:

Python脚本获取Linux系统信息

Python文件处理:读取文件

如何发布自定义的Python模块

Python爬虫多线程抓取代理服务器

Python中re(正则表达式)模块详解

Redis集群明细文档

Ubuntu 12.10下安装Redis(图文详解)+ Jedis连接Redis

Redis系列-安装部署维护篇

CentOS 6.3安装Redis

Redis 的详细介绍:请点这里
Redis 的下载地址:请点这里

Python 的详细介绍:请点这里
Python 的下载地址:请点这里

相关内容