Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/wjw465150/Pushlet

Pushlet 是一个开源的 Comet 框架,Pushlet 使用了观察者模型:客户端发送请求,订阅感兴趣的事件;服务器端为每个客户端分配一个会话 ID 作为标记,事件源会把新产生的事件以多播的方式发送到订阅者的事件队列里。
https://github.com/wjw465150/Pushlet

Last synced: about 2 months ago
JSON representation

Pushlet 是一个开源的 Comet 框架,Pushlet 使用了观察者模型:客户端发送请求,订阅感兴趣的事件;服务器端为每个客户端分配一个会话 ID 作为标记,事件源会把新产生的事件以多播的方式发送到订阅者的事件队列里。

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对象