Netty is throwing the following exception when i send a message asynchronously from my client and then close the channel.
java.nio.channels.ClosedChannelException
at sun.nio.ch.SocketChannelImpl.ensureWriteOpen(SocketChannelImpl.java:133)
at sun.nio.ch.SocketChannelImpl.write(SocketChannelImpl.java:324)
at org.jboss.netty.channel.socket.nio.SocketSendBufferPool$PooledSendBuffer.transferTo(SocketSendBufferPool.java:239)
at org.jboss.netty.channel.socket.nio.NioWorker.write0(NioWorker.java:469)
at org.jboss.netty.channel.socket.nio.NioWorker.writeFromTaskLoop(NioWorker.java:392)
at org.jboss.netty.channel.socket.nio.NioSocketChannel$WriteTask.run(NioSocketChannel.java:276)
at org.jboss.netty.channel.socket.nio.NioWorker.processWriteTaskQueue(NioWorker.java:268)
at org.jboss.netty.channel.socket.nio.NioWorker.run(NioWorker.java:199)
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:662)
My send code is as follows:
Channels.write(clientChannel, messageObject);
My close code is as follows:
ChannelGroupFuture future = ALL_CHANNELS.close();
future.awaitUninterruptibly();
if (null != clientBootstrap) {
clientBootstrap.releaseExternalResources();
}
Is there anything I need to do to flush the Channel before closing?
Sorry I don’t understand your problem. You now close the channel after the write is complete (like Veebs suggested) and now you complain it fails for new writes as the channel is closed ? If you need more then write operation you need to add the ChannelFutureListener.CLOSE to the last future that was returned.
Hope it helps..