在n个线程之间分配传入连接是否有利,每个线程都有自己的独立NIO Selector
,其中n是服务器中的核心数量?假设我正在编写一个服务器,它应该处理一些客户端连接。我可以有这样的事情:多线程中的多个选择器
selector.select();
Iterator<SelectionKey> i = selector.selectedKeys().iterator();
while (i.hasNext()) {
SelectionKey key = i.next();
i.remove();
if (!key.isValid())
continue;
if (key.isAcceptable()) {
// get one of the n selectors (I'd have one per core)
Selector chosenSelector = getRandomSelector();
// delegate the new connection to the chosen selector
SocketChannel newChannel = key.channel.accept();
newChannel.configureBlocking(false);
newChannel.register(chosenSelector, SelectionKey.OP_READ);
}
}
你们觉得这有道理吗?我的意思是,运行n个线程,每个都有不同的选择器?或者我应该坚持只有一个选择器线程来处理所有连接的OP_READ?或者也许别的东西?
保留不同客户端之间的消息顺序已经足够困难了,而不会故意使其更难。你打算如何完成它?时间戳? – EJP
我想订购邮件是一个正交的问题......一旦我收到它们,某人(一个线程)检查时间戳,并确保它们按正确的顺序处理,没有间隙。但我想我在这里问一些更基本的东西。 –