体验:http://120.27.28.160:8001/
体验帐号:admin 密码:admin
基于tornado框架 + sqlite3 + redis
多聊天室,多人实时聊天
开发语言: python2.7
web服务器: tornado
数据库: sqlite
缓存数据库: redis
- python 2.7+
- tornado
- redis server
- sqlite3
$ git clone https://githup.com/suliangxd/ChatRoom.git
$ cd ChatRoom
$ cd src
$ redis-server (开启redis服务)
$ python init_sqlite.py(初始化数据库)
$ python add_admin.py (添加管理员脚本)
$ python server.py
then open your browser and type http://127.0.0.1:8000
version 1.0 ##实时聊天功能基本架构 version 1.0
当用户进入某个聊天室,即相当于订阅了此聊天室对应在redis里的一个channel
这里给出的架构图是指用户进入聊天室之后的实时聊天架构
思路说明:前端基于ajax的longpolling,后端采用redis的sub/pub机制
1. 服务器端会阻塞请求直到有数据传递或超时才返回,这里设置超时时间为60s
2. 客户端JavaScript响应处理函数会在处理完服务器返回的信息后,再次发出请求,重新建立连接
出现的问题:
当客户端处理接收的数据、重新建立连接时,此时相当于取消订阅该房间的channel而服务器端可能有新的数据到达,
这样的情况下可能会造成数据丢失
--
![Login] (http://pic.sueri.cn/di-J5QC.jpg)
![ChatRoom] (http://pic.sueri.cn/di-O5Y6.png)
![Chat] (http://pic.sueri.cn/di-IGVR.jpg)