netty 超时后通道不关闭

Channel not closing after timeout in netty

我想在几秒钟后没有收到任何数据时关闭频道。我试过 IdleHandler,但它不起作用。我的主要处理程序是 clientHandler,它扩展了 SimpleChannelInboundHandler。这将以字符串格式发送数据并以字符串格式接收数据。有时,在那段时间我没有得到数据,我希望我的频道在一定的超时后关闭,但目前它正在等待来自服务器的数据。

再观察一次,当我检查数据包发送方以验证同一请求时。我从服务器收到空响应,但我的 ClientHandler 未收到此响应。

代码如下。

clientBootstrap.handler(new ChannelInitializer<SocketChannel>() {
                @Override
                public void initChannel(SocketChannel ch){
                    ch.pipeline()
                            .addLast(new IdleStateHandler(5, 5, 10))
                            .addLast(new MyHandler())
                            .addLast(new ClientHandler(cardIssueRequest,promise));
                }
            });

我的处理程序:

public class MyHandler extends ChannelDuplexHandler {
    @Override
    public void userEventTriggered(ChannelHandlerContext ctx, Object evt) {
        if (evt instanceof IdleStateEvent) {
            IdleStateEvent e = (IdleStateEvent) evt;
            if (e.state() == IdleState.READER_IDLE) {
                ctx.close();
            } else if (e.state() == IdleState.WRITER_IDLE) {
                ctx.close();
            }
        }
    }
}

客户端处理程序:

public  class ClientHandler extends SimpleChannelInboundHandler {

    RequestModel request;
    private final Promise<String> promise;

    public ClientHandler(RequestModel request, Promise<String> promise) {
        this.request = request;
        this.promise = promise;
    }

    @Override
    protected void channelRead0(ChannelHandlerContext channelHandlerContext, Object o) {
        String response = ((ByteBuf) o).toString(CharsetUtil.UTF_8);
        log.info("Client received: " + response);
        promise.trySuccess(response);
    }

    @Override
    public void channelActive(ChannelHandlerContext channelHandlerContext) {
        log.info("Client sent: " + request);
        channelHandlerContext.writeAndFlush(Unpooled.copiedBuffer((request.toString()), CharsetUtil.UTF_8));
    }

    @Override
    public void exceptionCaught(ChannelHandlerContext channelHandlerContext, Throwable cause) {
        cause.printStackTrace();
        channelHandlerContext.close();
        promise.setFailure(cause);
    }
}

进行线程转储后,我发现问题是我的程序在 promise 语句中等待。所以,在为承诺设置超时后,我的问题就解决了。

promise.get(60, TimeUnit.SECONDS)