我正在研究Netty应用程序。我想在不同的端口上运行多个服务器,如果没有(阻塞)closeFuture().sync()
,则无法运行。
我使用以下代码在ServerManager
类中启动服务器:
gpcmServer = new GpcmServer(port);
gpspServer = new GpspServer(port);
在这些课程中,我按如下方式启动服务器:
public GpspServer(int port) throws InterruptedException {
EventLoopGroup bossGroup = new NioEventLoopGroup();
EventLoopGroup workerGroup = new NioEventLoopGroup();
try {
ServerBootstrap bootstrap = new ServerBootstrap();
bootstrap.group(bossGroup, workerGroup)
.channel(NioServerSocketChannel.class)
.childHandler(new ChannelInitializer<SocketChannel>() {
@Override
public void initChannel(SocketChannel ch) throws Exception {
// Add the server handler and its decoder
ch.pipeline().addLast(new GpspDecoder(), new GpspServerHandler());
}
})
.option(ChannelOption.SO_BACKLOG, 128)
.childOption(ChannelOption.SO_KEEPALIVE, true);
// Bind and start to accept incoming connections.
bindFuture = bootstrap.bind(port).sync();
bindFuture.channel().closeFuture();
} finally {
workerGroup.shutdownGracefully();
bossGroup.shutdownGracefully();
}
}
但是,当我不致电closeFuture().sync()
时,我无法连接到服务器。当我将.sync()
添加到bindFuture.channel().closeFuture()
时,我可以连接到服务器。我如何继续这样做,仍然使服务器工作?
答案 0 :(得分:7)
当您调用EventLoopGroup.shutdown*()
方法时,事件循环将关闭它正在管理的所有套接字和服务器套接字,然后再终止自身。因此,如果您没有等到服务器套接字关闭,那么finally
块将完全终止您的服务器。
运行多台服务器实际需要做的是:
shutdownGracefully()
,直到您要关闭服务器。