微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

An exceptionCaught() event was fired, and it reached at the tail of the pipeline. It usually means

问题描述:

警告: An exceptionCaught() event was fired,and it reached at the tail of the pipeline. It usually means the last handler in the pipeline did not handle the exception.
java.io.IOException: 远程主机强迫关闭一个现有的连接。
    at sun.nio.ch.socketdispatcher.read0(Native Method)
    at sun.nio.ch.socketdispatcher.read(UnkNown Source)
    at sun.nio.ch.IoUtil.readIntoNativeBuffer(UnkNown Source)
    at sun.nio.ch.IoUtil.read(UnkNown Source)
    at sun.nio.ch.socketChannelImpl.read(UnkNown Source)
    at io.netty.buffer.UnpooledUnsafeDirectByteBuf.setBytes(UnpooledUnsafeDirectByteBuf.java:446)
    at io.netty.buffer.AbstractByteBuf.writeBytes(AbstractByteBuf.java:871)
    at io.netty.channel.socket.nio.NioSocketChannel.doReadBytes(NioSocketChannel.java:208)
    at io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:119)
    at io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:485)
    at io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:452)
    at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:346)
    at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:794)
    at java.lang.Thread.run(UnkNown Source)

我这里问题发生原因是服务端未给客户端回应消息前客户端提前关闭连接造成。

解决方案:

@Override
    public void exceptionCaught(ChannelHandlerContext ctx,Throwable cause) throws Exception {
        super.exceptionCaught(ctx,cause);
        Channel channel = ctx.channel();
        //……
        if(channel.isActive())ctx.close();
    }

原文地址:https://www.jb51.cc/javaschema/283678.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐