线程模型因您使用的连接器而异。对于可伸缩性,您想使用 NIO(默认)或 APR/native(8.0.0-RC3 的错误)。NIO确实是目前唯一的选择。APR/native 问题应该很快得到解决(当我看到这个问题时,我正在处理这个问题)。
NIO 使用选择器和线程池来处理接收到的消息。When the selector detects that data is available it passes the socket to a thread from the thread pool (via an executor) to process it. 该处理可能导致数据在内部被缓冲,应用程序被通知部分消息,应用程序被通知完整消息或这些的组合。对应用程序的通知由处理传入数据的同一线程处理。
如果从多个客户端接收到多条消息,则将分派多个线程来处理这些消息。
JSR 356 API 中没有任何功能允许应用程序选择通过 ExecutorService 处理的消息或部分消息,即应用程序已被通知新消息而没有应用程序实现。对于只处理整个消息的应用程序来说,实现这一点应该相对简单。如果应用程序处理部分消息,那么这将更加困难。
APR/native(一旦修复)的行为方式与 NIO 相同。BIO 始终使用阻塞 IO(即使 JSR356 API 指示非阻塞)并且还需要每个连接的客户端一个线程,而不是每个连接的客户端一个线程来处理数据。