2

我的应用程序通过 Tomcat 8.5(servlet 3.1)的 JSR 356 实现使用 Web Sockets。根据 JSR,它应该使用 NIO,但我不确定是否理解。

当客户端请求 Web Socket 连接时,客户端和服务器之间会创建一个永久对话。在这种情况下,我想知道客户端或服务器的每个请求是否由 Tomcat 池的不同线程处理,或者是否始终专用于该连接。

此外,该线程如何处理请求?例如,它是等待 JDBC 调用(阻塞 IO)还是在这种情况下释放(NIO)?与众所周知的仅使用 NIO 的 Netty 相比,Tomcat 线程模型在 websocket 案例中有何不同/相似?

4

1 回答 1

3

当有数据要处理时,从池中分配一个线程来处理 WebSocket 连接上的传入数据。一旦完成,线程将返回到池中。有可能(实际上很可能)每次都使用不同的线程。

传出消息将使用阻塞或非阻塞 IO,具体取决于使用 API 的哪一部分。

JDBC 调用通常会阻塞,但由 JDBC 驱动程序控制。应用程序如何处理 JDBC 调用以及与 WebSocket 消息的关系(如果有)取决于应用程序。

于 2018-02-19T11:13:56.380 回答