writeAndFlush 后,handle 中只有编码工作没有耗时动作,延迟竟然达到 500ms, 期间 epollEventLoopGroup 线程没有作任何事情。 可能是什么原因呢,buffer 肯定也没满,难道 io 线程 hang 住了?
long writeTime = System.currentTimeMillis();
channel.writeAndFlush(message).addListener(new ChannelFutureListener() { @Override public void operationComplete(ChannelFuture future) throws Exception { if (future.isSuccess()) { log.info("flush 延迟:{}",successTime - writeTime) } }); }
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.