java netty socket_netty-socket

public abstract class NettyYmaServer extends SessionAbleYmaServer {

private static final Logger log = LoggerFactory.getLogger(NettyYmaServer.class);

private final YmlServerConfig config;

private Channel serverChannel;

public NettyYmaServer(YmlServerConfig config){

this.config = config;

}

public NettyYmaServer(){

this(new DefaultServerConfig());

}

@Override

public void start(){

ServerBootstrap bootstrap = new ServerBootstrap();

bootstrap.group(config.getBoosGroup(),config.getWorkerGroup())

.channel(NioServerSocketChannel.class)

.handler(new LoggingHandler(LogLevel.INFO))

.childHandler(new ChannelInitializer() {

@Override

protected void initChannel(SocketChannel channel) throws Exception {

channel.pipeline()

.addLast(new ByteArrayEncoder())

.addLast(new ByteArrayDecoder())

.addLast(NettyYmaServer.this);

}

});

ChannelFuture future = bootstrap.bind(config.getSocketAddress());

future.addListener(f -> {

if(f.isDone() && f.isSuccess()){

this.serverChannel = future.channel();

log.info("Start ws server success");

}

if(f.isDone() && f.cause() != null){

log.error("Start ws server fail throw={}", f.cause().getMessage());

future.channel().close();

}

});

}

@Override

public void stop(){

if(serverChannel != null && serverChannel.isOpen()){

final int waitSec = 10;

CountDownLatch latch = new CountDownLatch(1);

serverChannel.close().addListener(f -> {

config.getWorkerGroup().schedule(() -> {

log.info("Shutdown dispatcher success...");

config.getWorkerGroup().shutdownGracefully();

latch.countDown();

}, waitSec - 2, TimeUnit.SECONDS);

log.info("Close ws server socket success={}", f.isSuccess());

config.getBoosGroup().shutdownGracefully();

});

try{

latch.await(waitSec, TimeUnit.SECONDS);

}catch (InterruptedException e){

log.warn("Shutdown ws server interrupted exception={}", e.getMessage());

}

}

}

....

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值