Netty 通道中的NPE.write(对象消息)

Netty 通道中的NPE.write(对象消息),netty,Netty,我正在运行一个基于netty(3.2.5.Final.jar)的(自制的)中间件“服务连接器(SC)”,它基本上是http流量的代理。任何传入的请求都会转发到远程节点,最后是apache public void messageReceived(ChannelHandlerContext ctx, MessageEvent event) throws Exception { ChannelBuffer msg = (ChannelBuffer) event.getMessage()

我正在运行一个基于netty(3.2.5.Final.jar)的(自制的)中间件“服务连接器(SC)”,它基本上是http流量的代理。任何传入的请求都会转发到远程节点,最后是apache

public void messageReceived(ChannelHandlerContext ctx, MessageEvent event) throws Exception {
        ChannelBuffer msg = (ChannelBuffer) event.getMessage();
        outboundChannel.write(msg);
}
我正在通过浏览器向SC发送请求,例如:http://localhost:9104/testHtml.htm"

它通常工作完美!偶尔浏览器会永远循环。不同的模式(不同的文件、大小、时间)

查看网络日志:

2012-11-28 17:54:12.326+0100 [New I/O server boss #9 ([id: 0x015bdc50, /10.43.18.160:9104])] DEBUG (org.jboss.netty.handler.logging.LoggingHandler:39) - [id: 0x00f6fd54, /10.43.18.160:52499 => /10.43.18.160:9104] OPEN
2012-11-28 17:54:12.342+0100 [New I/O server boss #9 ([id: 0x015bdc50, /10.43.18.160:9104])] DEBUG (org.jboss.netty.handler.logging.LoggingHandler:39) - [id: 0x00f6fd54, /10.43.18.160:52499 => /10.43.18.160:9104] BOUND: /10.43.18.160:9104
2012-11-28 17:54:12.357+0100 [New I/O server boss #9 ([id: 0x015bdc50, /10.43.18.160:9104])] DEBUG (org.jboss.netty.handler.logging.LoggingHandler:39) - [id: 0x00f6fd54, /10.43.18.160:52499 => /10.43.18.160:9104] CONNECTED: /10.43.18.160:52499
2012-11-28 17:54:12.342+0100 [SC_WORKER thread-13] DEBUG (org.jboss.netty.handler.logging.LoggingHandler:39) - [id: 0x00f6fd54, /10.43.18.160:52499 => /10.43.18.160:9104] CHANGE_INTEREST: 0
2012-11-28 17:54:12.420+0100 [New I/O server worker #9-20] DEBUG (org.jboss.netty.handler.logging.LoggingHandler:39) - [id: 0x00f6fd54, /10.43.18.160:52499 => /10.43.18.160:9104] RECEIVED: BigEndianHeapChannelBuffer(ridx=0, widx=501, cap=501) - (HEXDUMP: ....)
2012-11-28 17:54:12.435+0100 [SC_WORKER thread-13] DEBUG (org.jboss.netty.handler.logging.LoggingHandler:39) - [id: 0x00f6fd54, /10.43.18.160:52499 => /10.43.18.160:9104] INTEREST_CHANGED
2012-11-28 17:54:12.451+0100 [SC_WORKER thread-11] DEBUG (org.jboss.netty.handler.logging.LoggingHandler:43) - [id: 0x00f6fd54, /10.43.18.160:52499 => /10.43.18.160:9104] EXCEPTION: java.lang.NullPointerException
java.lang.NullPointerException
    at org.serviceconnector.net.res.netty.tcp.proxy.NettyTcpProxyResponderRequestHandler.messageReceived(NettyTcpProxyResponderRequestHandler.java:127)
    at org.jboss.netty.handler.execution.ChannelEventRunnable.run(ChannelEventRunnable.java:69)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
    at java.lang.Thread.run(Thread.java:619) 
在调试模式下,我可以看到msg或outboundChannel为空:/ 如果我把代码改成下面的代码,它就会工作

如果出现错误,只需再写一遍

try{
  outboundChannel.write(msg);
} catch(Throwable t) {
  outboundChannel.write(msg);
}
或者放慢线的速度

Thread.sleep(200);
outboundChannel.write(msg);
我想我正面临一个比赛条件。它只发生在速度较慢的机器上 当然,它很难复制。我不能提供一个例子

我以同样的行为尝试了netty 3.5.10.决赛。有人观察到类似的行为吗?
谢谢

outboundChannel
只有在
channelOpen
之前调用
messageReceived
时才能为
null
。通常情况下,这种情况不会发生,但如果管道在处理程序之前有一个
ExecutionHandler
,并且您使用的是无序的executor服务,则可能发生这种情况。如果是这样,请使用
ExecutorService
,例如
OrderedMemoryAwareThreadPoolExecutor

请向我展示您的完整处理程序..当然:非常抱歉,显然我没有仔细阅读ExecutionHandler API:/!