`
erylee
  • 浏览: 108138 次
社区版块
存档分类
最新评论

Facebook, Gmail, 校内Web即时通信方案介绍

阅读更多

<!----><!---->

www.facebook.com

<!----><!---->

Facebook是最早推出WebIM功能的SNS社区网站之一,Facebook IM的后台采用Erlang实现大规模的WebIM服务器集群,前台通过IFrame+AJAX实现跨域长轮询。


方案综述:后台采用PHP+Erlang实现,前台IM界面直接嵌入Facebook所有主要页面中,前后台通过POST发送消息,通过Iframe+AJAX的长轮询(long poll)方式接收消息(Message)和好友状态(Presence)。

发送消息:  POST http://www.facebook.com/ajax/chat/***.php

接收消息: GET http://0.channel17.facebook.com/x/1473685292/false/p_517871768=4

通过嵌入Iframe解决Ajax轮询代码的跨域问题: <iframe id="channel_iframe"/>

www.xiaonei.com

校内网IM是一个完整的即时通信产品,不仅包括WebIM,还有桌面版本,其整个方案相对Facebook更完整。


校内IM是采用Jabber的XMPP协议,具体后台Jabber服务器应该是Ejabberd之类,桌面版本直连Jabber服务器,WEB版本通过Flash连接Jabber服务器。


方案综述:校内是采用Flash长连接的方式实现即时消息收发,这一点比较特别,个人认为原因有两点:1. 校内网是采用Java做的,即时消息处理上如果采用Ajax的方式,服务器压力较大;2. 后台的Jabber服务器需要建立长连接。

消息收发:通过flash链接Jabber服务器的39000端口。

www.gmail.com

GTalk in Gmail的WebIM估计是因为借助了Google强大的后台集群Web服务器,前台实现得非常简单,连跨域都没有,就是通过定时轮询(以前是长轮询,现在是短轮询)的方式来接收即时消息和好友状态。


 

2
4
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics