哪些特定用例通过WebSockets和长轮询调用BOSH?

时间:2011-06-22 01:59:14

标签: http comet websocket bosh

BOSH是......

  

传输协议,通过有效地使用多个同步HTTP请求/响应对来模拟两个实体(例如客户端和服务器)之间的长期双向TCP连接的语义,而无需使用频繁轮询或分块响应。

这听起来像WebSockets和HTTP长轮询,除了它使用两个开放的HTTP连接而不是一个,并且不扩展HTTP协议。

两个协议之间有什么区别,哪个用例更喜欢WebSockets而不是BOSH?

1 个答案:

答案 0 :(得分:102)

首先让我解决WebSockets就绪问题

Hixie-76协议的WebSockets实施默认在Chrome,Safari和iOS(iPhone和iPad)中发布并启用。 Hixie-76协议也出厂但默认情况下在Firefox 4和Opera 11中被禁用。web-socket-js项目是Flash shim / polyfill,它为任何带Flash的浏览器添加了WebSocket(Hixie-76)支持。

换句话说,WebSockets几乎适用于所有浏览器。

Opera和Mozilla之所以默认选择禁用该协议,是因为理论上担心可能会有一些破坏的HTTP代理/中介使用协议的Hixie版本进行攻击/中毒。同样的问题也适用于Flash,但Mozilla和Opera对他们发布的代码负有更高的责任。 HyBi版本的协议(该协议被移至IETF HyBi工作组)解决了安全问题。

Mozilla,Opera,Google和Microsoft都致力于HyBi协议的实施(尽管微软目前正在将它们作为separate download进行维护)。有branch of web-socket-js支持HyBi-07。

更新:截至2013年2月,Chrome 14,Firefox 7,IE10,Opera 12.1,Safari 6.0以及HyBi/IETF RFC 6455 spec Flash支持最新的web-socket-js垫片/填充工具。在移动设备上,iOS 6.0上的Safari,Opera Mobile 12.1,Android版Chrome 14,Android版Firefox 7和Blackberry 7支持IETF6455.原始默认Android浏览器没有任何WebSocket支持。

WebSocket服务器易于实现。有许多独立和插件实现,其中大多数都支持Hixie-76和HyBi协议版本:

BOSH vs WebSockets

  • 延迟:虽然BOSH草案文件声称延迟非常低,但BOSH很难与WebSockets竞争。除非你有理想的条件,所有中介和目标服务器都支持HTTP / 1.1,否则BOSH客户端和连接管理器将需要在每个数据包和每个请求超时后重新建立连接。这将显着增加延迟和延迟抖动。对于实时应用,低抖动通常比平均延迟更重要。 WebSocket连接在延迟和抖动方面与原始TCP连接非常相似。即使在理想条件下,BOSH通信的客户端到服务器延迟(因此往返)也总是高于WebSockets:BOSH仍然必须遵守HTTP请求 - 响应语义。 HTTP流式传输可以为每个请求提供多个响应(通过将“单个”响应拆分为多个部分),反之亦然(反之亦然)(每个客户端消息都是新请求)。
  • 小数据包开销:在WebSockets中,有两个字节的小帧开销 消息。在BOSH中,每条消息都有HTTP请求和响应头(每次往返都容易180多字节)。此外,每条消息都包含在XML中(据说是可选的,但规范没有定义如何)与几个会话相关的属性。
  • 复杂性:虽然BOSH在浏览器中使用现有机制,但它需要一个中等复杂的JavaScript库来实现BOSH语义。与本机/浏览器(甚至Flash)实现相比,在Javascript中管理此操作也会增加延迟和抖动。
  • 牵引力:BOSH开始以提高XMPP的效率。它是从XMPP社区中长大的,而且从我所知道的那个社区之外的关注很少。 BOSH和XMPP的文件草案分开,但没有XMPP,BOSH的实际使用情况似乎很少。

<强>更新

刚刚找到了Ian Fette讨论advantages of WebSockets over the Channel API which is similar to BOSH(44:00)

的视频