回退如何与 socket.io 一起使用?

How does fallback work with socket.io?

我想将 WebSocketJava 一起使用。问题是,我的服务器通过无法配置的代理与客户端分开。我一直在寻找 WebSocket 的实现以及 long-polling 等回退。我找到了 socket.io 但不知道回退是如何工作的。

在什么情况下它会取代WebSocket以及如何取代?

是否有其他类似 socket.io 的库具有回退实现?我想在 Java 中找到一个,但我只找到了 Jetty.

编辑:回退是否仅取决于浏览器与 WebSocket 的兼容性?如果失败的原因是代理配置错误怎么办,socket.io 是否会将其检测为兼容性故障并因此切换到长轮询(或其他技术)?

答案:从v1开始,socket.io包括engine.io,带来了以下特点:

Socket.io 是 websockets 协议的几个实现之一,它的主要卖点 (IMO) 是它的易用性:你不需要编写保持活动机制的代码或决定哪种传输是最好的,它会为你做。

所以,要明确一点,socket.io 不会取代 websocket 协议,它是一个为您实现它的包。

您提到了长轮询。这是 socket.io 使用的一种传输方式。长轮询是基于 HTTP 的,它基本上是请求 --> 等待 --> 响应,等待时间不会很长,因为它可能会在 EOF 或失效连接上被负载均衡器丢弃。尽管如此,当 websockets 协议(基于 TCP)不可用并且 socket.io 自动为您重新建立连接时,它仍然有用。请注意,websockets 是一个相对较新的协议,于 2011 年获得批准,因此较旧的浏览器不支持它。好吧,socket.io 会检测到这一点,然后求助于长轮询,因此您不必 "worry" 关于它。

websocket 连接以 HTTP 开始,监听相同的端口。例如,http://localhost:8080(只是一个愚蠢的例子)。然后,如果可能,socket.io 会为您切换到 ws://localhost:8080。

我在使用 socket.io 时从未遇到过网络拓扑挑战的问题,因为当 HTTP 端口可用并且可以使用长轮询/websockets 时,它对我有用。

正如您提到的,具有后备实现的库之一是 netty-socket.io。注意它是如何配置两种传输方式的:

public class Configuration {

    private ExceptionListener exceptionListener = new DefaultExceptionListener();

    private String context = "/socket.io";

    private List<Transport> transports = Arrays.asList(Transport.WEBSOCKET, Transport.POLLING);

    private int bossThreads = 0; // 0 = current_processors_amount * 2
    private int workerThreads = 0; // 0 = current_processors_amount * 2

完整代码可见here.

Node JS 也有用于 websockets 的库,我在这里提到它只是为了澄清长轮询和 websockets 不是仅有的两种可用传输(可能是 Java 中唯一的):

io.set('transports', [                     // enable all transports (optional if you want flashsocket)
            'websocket'
          , 'flashsocket'
          , 'htmlfile'
          , 'xhr-polling'
          , 'jsonp-polling'
        ]);

简而言之,socket.io 试图让事情尽可能简单,包括不必担心使用什么传输,因为它是在后台为您完成的,但如果您仍然可以配置想要。

希望这个简短的解释对您有所帮助!