Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wjw465150/Pushlet
Pushlet 是一个开源的 Comet 框架,Pushlet 使用了观察者模型:客户端发送请求,订阅感兴趣的事件;服务器端为每个客户端分配一个会话 ID 作为标记,事件源会把新产生的事件以多播的方式发送到订阅者的事件队列里。
https://github.com/wjw465150/Pushlet
Last synced: 3 months ago
JSON representation
Pushlet 是一个开源的 Comet 框架,Pushlet 使用了观察者模型:客户端发送请求,订阅感兴趣的事件;服务器端为每个客户端分配一个会话 ID 作为标记,事件源会把新产生的事件以多播的方式发送到订阅者的事件队列里。
- Host: GitHub
- URL: https://github.com/wjw465150/Pushlet
- Owner: wjw465150
- Created: 2011-11-01T05:58:42.000Z (about 13 years ago)
- Default Branch: branch-redis
- Last Pushed: 2014-08-19T09:07:08.000Z (over 10 years ago)
- Last Synced: 2024-08-01T16:32:33.077Z (6 months ago)
- Language: JavaScript
- Homepage:
- Size: 6.89 MB
- Stars: 153
- Watchers: 20
- Forks: 78
- Open Issues: 0
-
Metadata Files:
- Readme: README
Awesome Lists containing this project
README
Pushlet是通过改进[http://www.pushlets.com/](http://www.pushlets.com/)一个开源的Comet框架,添加支持多字符集和通过redis做后端数据库来做集群.
Pushlet 使用了观察者模型:客户端发送请求,订阅感兴趣的事件;服务器端为每个客户端分配一个会话 ID 作为标记,
事件源会把新产生的事件以多播的方式发送到订阅者的事件队列里。Redis分支的数据模型:
ZSET:
"p:zset:as" //存放所有的session;score是一个时间戳,value是sessionid
"p:zset:sj:"+oneSubject //score是一个时间戳,value是sessionid;目的是能从一个oneSubject里获取到所有的session.
HASH:
"p:sr:"+sessionid //field是Subscriber对象的属性名, value是Subscriber对象的属性值
"p:sc:"+sessionid //field是Subscription对象的Subject属性, value是Subscription对象
"p:sj:"+oneSubject //field是sessionid, value是Subscription对象的Subject属性;目的是能快速匹配到一个Subscription对象
"p:ss:"+sessionid //field是Session对象的属性名, value是Session对象的属性值
LIST:
"p:eq:"+sessionid //存放Event对象