Skip to content
/ Pushlet Public
forked from wjw465150/Pushlet

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

Notifications You must be signed in to change notification settings

xrogzu/Pushlet

 
 

Repository files navigation

Pushlet是通过改进https://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对象

About

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

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published