网络超时后频道未关闭

时间:2018-10-25 06:12:38

标签: java sockets asynchronous 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));
                }
            });

MyHandler:

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();
            }
        }
    }
}

ClientHandler:

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);
    }
}

1 个答案:

答案 0 :(得分:0)

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

promise.get(60, TimeUnit.SECONDS)