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)
我想在几秒钟后没有收到任何数据时关闭频道。我试过 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)