當前位置: 首頁>>代碼示例>>Java>>正文


Java NioEventLoopGroup.shutdownGracefully方法代碼示例

本文整理匯總了Java中io.netty.channel.nio.NioEventLoopGroup.shutdownGracefully方法的典型用法代碼示例。如果您正苦於以下問題:Java NioEventLoopGroup.shutdownGracefully方法的具體用法?Java NioEventLoopGroup.shutdownGracefully怎麽用?Java NioEventLoopGroup.shutdownGracefully使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在io.netty.channel.nio.NioEventLoopGroup的用法示例。


在下文中一共展示了NioEventLoopGroup.shutdownGracefully方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: startNotificationRegisterEndpoint

import io.netty.channel.nio.NioEventLoopGroup; //導入方法依賴的package包/類
protected void startNotificationRegisterEndpoint(final String host, final int port) {

        Runnable notificationRegisterEndpointRunnable = new Runnable() {

            @Override
            public void run() {
                bossGroup = new NioEventLoopGroup(1);
                workerGroup = new NioEventLoopGroup();

                try {
                    ServerBootstrap b = new ServerBootstrap();
                    b.option(ChannelOption.SO_BACKLOG, 1024);
                    b.group(bossGroup, workerGroup)
                        .channel(NioServerSocketChannel.class)
                        .handler(new LoggingHandler(LogLevel.INFO))
                        .childHandler(new NotificationRegisterServerInitializer());

                    Channel ch = b.bind(host, port).sync().channel();

                    logger.info(String.format("Notification register endpoint started at %s:%s", host, port));

                    ch.closeFuture().sync();
                } catch (InterruptedException ex) {
                    logger.info("Notification register endpoint was interrupted.");
                } finally {
                    bossGroup.shutdownGracefully();
                    workerGroup.shutdownGracefully();
                }

            }
        };

        notificationEndpointThread = new Thread(notificationRegisterEndpointRunnable);
        notificationEndpointThread.start();
    }
 
開發者ID:aerogear,項目名稱:push-network-proxies,代碼行數:36,代碼來源:NotificationRegisterEndpoint.java

示例2: start

import io.netty.channel.nio.NioEventLoopGroup; //導入方法依賴的package包/類
public void start() {
    Configuration config = Configuration.INSTANCE;
    InternalLoggerFactory.setDefaultFactory(Slf4JLoggerFactory.INSTANCE);
    bossGroup = new NioEventLoopGroup(1);
    workerGroup = new NioEventLoopGroup();
    try {
        ServerBootstrap bootstrap = new ServerBootstrap();
        bootstrap.group(bossGroup, workerGroup)
                .channel(NioServerSocketChannel.class)
                .childHandler(new ChannelInitializer<SocketChannel>() {
                    @Override
                    protected void initChannel(SocketChannel socketChannel) throws Exception {
                        socketChannel.pipeline()
                                .addLast("logging", new LoggingHandler(LogLevel.DEBUG))
                                .addLast(new SocksInitRequestDecoder())
                                .addLast(new SocksMessageEncoder())
                                .addLast(new Socks5Handler())
                                .addLast(Status.TRAFFIC_HANDLER);
                    }
                });
        log.info("\tStartup {}-{}-client [{}{}]", Constants.APP_NAME, Constants.APP_VERSION, config.getMode(), config.getMode().equals("socks5") ? "" : ":" + config.getProtocol());
        new Thread(() -> new UdpServer().start()).start();
        ChannelFuture future = bootstrap.bind(config.getLocalHost(), config.getLocalPort()).sync();
        future.addListener(future1 -> log.info("\tTCP listening at {}:{}...", config.getLocalHost(), config.getLocalPort()));
        future.channel().closeFuture().sync();
    } catch (Exception e) {
        log.error("\tSocket bind failure ({})", e.getMessage());
    } finally {
        log.info("\tShutting down");
        bossGroup.shutdownGracefully();
        workerGroup.shutdownGracefully();
    }
}
 
開發者ID:ZhangJiupeng,項目名稱:AgentX,代碼行數:34,代碼來源:XClient.java

示例3: start

import io.netty.channel.nio.NioEventLoopGroup; //導入方法依賴的package包/類
public void start(int port) {
    bossGroup = new NioEventLoopGroup();
    workerGroup = new NioEventLoopGroup();
    try {
      ServerBootstrap b = new ServerBootstrap();
      b.group(bossGroup, workerGroup)
          .channel(NioServerSocketChannel.class)
//          .option(ChannelOption.SO_BACKLOG, 100)
//          .handler(new LoggingHandler(LogLevel.DEBUG))
          .childHandler(new ChannelInitializer<Channel>() {

            @Override
            protected void initChannel(Channel ch) throws Exception {
              ch.pipeline().addLast("httpCodec", new HttpServerCodec());
              ch.pipeline().addLast("serverHandle",
                  new HttpProxyServerHandle(serverConfig, proxyInterceptInitializer, proxyConfig,
                      httpProxyExceptionHandle));
            }
          });
      ChannelFuture f = b
          .bind(port)
          .sync();
      f.channel().closeFuture().sync();
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
      bossGroup.shutdownGracefully();
      workerGroup.shutdownGracefully();
    }
  }
 
開發者ID:monkeyWie,項目名稱:proxyee,代碼行數:31,代碼來源:HttpProxyServer.java

示例4: startServer

import io.netty.channel.nio.NioEventLoopGroup; //導入方法依賴的package包/類
/**
 * 初始化
 *
 * @throws Exception
 */
public void startServer(int port) throws Exception {
    NioEventLoopGroup bossGroup = new NioEventLoopGroup(1);
    NioEventLoopGroup workGroup = new NioEventLoopGroup();
    try {
        ServerBootstrap bootstrap = new ServerBootstrap();
        bootstrap.group(bossGroup, workGroup)
                .channel(NioServerSocketChannel.class)
                .handler(new LoggingHandler())
                .childHandler(new ChannelInitializer<Channel>() {
                    @Override
                    protected void initChannel(Channel ch) throws Exception {
                        ch.pipeline().addLast(new RequestWrapperCodec())
                                .addLast(new ResponseWrapperCodec())
                                .addLast(new BusinessServerHandler());
                    }
                });
        ChannelFuture channelFuture = bootstrap.bind(port).sync();
        channelFuture.addListener((future) -> System.out.println("server listening at: " + ((ChannelFuture) future).channel()));
        channelFuture.channel().closeFuture().sync();
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        bossGroup.shutdownGracefully();
        workGroup.shutdownGracefully();
    }
}
 
開發者ID:recklessMo,項目名稱:nettyRpc,代碼行數:32,代碼來源:RpcServer.java

示例5: main

import io.netty.channel.nio.NioEventLoopGroup; //導入方法依賴的package包/類
public static void main(String[] args) throws InterruptedException, NoSuchAlgorithmException {
  InetSocketAddress addr = new InetSocketAddress(GOOGLE_SERVER_HOST, GOOGLE_SERVER_PORT);

  System.out.printf("Sending request to %s\n", addr);

  // Below is Netty boilerplate for setting-up an event loop and registering a handler

  NioEventLoopGroup group = new NioEventLoopGroup();
  Bootstrap bootstrap = new Bootstrap()
      .group(group)
      .remoteAddress(addr)
      .channel(NioDatagramChannel.class)
      .handler(new ChannelInitializer<NioDatagramChannel>() {
        @Override
        protected void initChannel(NioDatagramChannel ch) throws Exception {
          ch.pipeline()
              .addLast(new ReadTimeoutHandler(5))
              .addLast(new RequestHandler(addr));
        }
      });

  ChannelFuture connectFuture = bootstrap.connect();
  connectFuture.addListener(fut -> {
    if (!fut.isSuccess()) {
      System.out.println("Connect fail:");
      System.out.println(fut.cause().getMessage());
    }
  });

  connectFuture.channel().closeFuture().sync();
  group.shutdownGracefully();
}
 
開發者ID:int08h,項目名稱:nearenough,代碼行數:33,代碼來源:NettyClient.java

示例6: start

import io.netty.channel.nio.NioEventLoopGroup; //導入方法依賴的package包/類
public void start(int port) {

        bossGroup = new NioEventLoopGroup(1);
        workerGroup = new NioEventLoopGroup();

        ethereumChannelInitializer = ctx.getBean(EthereumChannelInitializer.class, "");

        ethereumListener.trace("Listening on port " + port);


        try {
            ServerBootstrap b = new ServerBootstrap();

            b.group(bossGroup, workerGroup);
            b.channel(NioServerSocketChannel.class);

            b.option(ChannelOption.SO_KEEPALIVE, true);
            b.option(ChannelOption.MESSAGE_SIZE_ESTIMATOR, DefaultMessageSizeEstimator.DEFAULT);
            b.option(ChannelOption.CONNECT_TIMEOUT_MILLIS, config.peerConnectionTimeout());

            b.handler(new LoggingHandler());
            b.childHandler(ethereumChannelInitializer);

            // Start the client.
            logger.info("Listening for incoming connections, port: [{}] ", port);
            logger.info("NodeId: [{}] ", Hex.toHexString(config.nodeId()));

            channelFuture = b.bind(port).sync();

            listening = true;
            // Wait until the connection is closed.
            channelFuture.channel().closeFuture().sync();
            logger.debug("Connection is closed");

        } catch (Exception e) {
            logger.debug("Exception: {} ({})", e.getMessage(), e.getClass().getName());
            throw new Error("Server Disconnected");
        } finally {
            workerGroup.shutdownGracefully();
            bossGroup.shutdownGracefully();
            listening = false;
        }
    }
 
開發者ID:talentchain,項目名稱:talchain,代碼行數:44,代碼來源:PeerServer.java

示例7: start

import io.netty.channel.nio.NioEventLoopGroup; //導入方法依賴的package包/類
/**
 * 步驟:
 * 1.創建一個ServerBootstrap的實例以引導和綁定服務器
 * 2.創建並分配一個NioEventLoopGroup實例以進行事件的處理,如接受新連接以及讀/寫數據
 * 3.指定服務器綁定的本地的InetSocketAddress
 * 4.使用一個EchoServerHandler的實例初始化每一個新的Channel
 * 5.調用ServerBootstrap.bind()方法以綁定服務器
 */
public void start() {

    /**
     * 創建EventLoopGroup
     * NioEventLoopGroup用來接收和處理新的連接
     */
    NioEventLoopGroup loopGroup = new NioEventLoopGroup();
    try {

        /**
         * 1.創建 ServerBootstrap
         */
        new ServerBootstrap()
                .group(loopGroup)

                /**
                 * 2.指定所使用的NIO傳輸Channel
                 */
                .channel(NioServerSocketChannel.class)

                /**
                 * 3.使用指定的端口設置套接字地址
                 */
                .localAddress(new InetSocketAddress(port))

                /**
                 * 4.添加一個EchoServerHandler到子Channel的ChannelPipeline
                 *      當一個新的連接被接受時,一個新的子Channel將會被創建
                 *      ChannelInitializer會把一個EchoServerHandler的實例添加到該Channel的ChannelPipeline中
                 */
                .childHandler(new ChannelInitializer() {
                    @Override
                    protected void initChannel(Channel ch) throws Exception {

                        /**
                         * EchoServerHandler 被標注為@Shareable,所以我們可以總是使用同樣的實例
                         */
                        ch.pipeline().addLast(new EchoServerHandler());
                    }
                })

                /**
                 * 5.異步地綁定服務器,調用sync()方法阻塞等待直到綁定完成
                 *      返回 ChannelFuture
                 */
                .bind().sync()

                /**
                 * 6.獲取Channel的CloseFuture,並且阻塞當前線程直到它完成
                 */
                .channel().closeFuture().sync();
    } catch (InterruptedException e) {
        e.printStackTrace();
    } finally {
        /**
         * 7.關閉EventLoopGroup,釋放所有的資源
         */
        loopGroup.shutdownGracefully();
    }
}
 
開發者ID:cbooy,項目名稱:cakes,代碼行數:69,代碼來源:EchoServer.java

示例8: start

import io.netty.channel.nio.NioEventLoopGroup; //導入方法依賴的package包/類
/**
 * 啟動
 *
 * @throws Exception
 */
public void start() throws Exception {
    bossGroup = new NioEventLoopGroup(1);
    workerGroup = new NioEventLoopGroup(workerNum);
    NrpcServer nrpcServer = this;
    entryThread = new Thread(
            new Runnable() {
                @Override
                public void run() {
                    try {
                        ServerBootstrap bootstrap = new ServerBootstrap();
                        bootstrap.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class)
                                .childHandler(new ChannelInitializer<SocketChannel>() {
                                    @Override
                                    public void initChannel(SocketChannel ch)
                                            throws Exception {
                                        // 注冊handler
                                        ch.pipeline().addLast(new NrpcDecoder(), new NrpcClientHandler(nrpcServer));
                                    }
                                })
                                .option(ChannelOption.SO_BACKLOG, 128)
                                .option(ChannelOption.SO_REUSEADDR, true)
                                .childOption(ChannelOption.SO_KEEPALIVE, true)
                                .childOption(ChannelOption.TCP_NODELAY, true)
                                .childOption(ChannelOption.SO_RCVBUF, 1048576)
                                .childOption(ChannelOption.SO_SNDBUF, 1048576);
                        // Bind and start to accept incoming connections.
                        ChannelFuture future = bootstrap.bind("0.0.0.0",port).sync();
                        // begin to check service
                        nrpcServiceRegistry.startCheckService();
                        // Wait until the server socket is closed.
                        // In this example, this does not happen, but you can do that to gracefully
                        // shut down your server.
                        future.channel().closeFuture().sync();
                    } catch (Exception ex){
                        logger.error(ex.getMessage(),ex);
                    } finally {
                        workerGroup.shutdownGracefully();
                        bossGroup.shutdownGracefully();
                    }
                }
            },"NrpcServer-"+atomicInteger.addAndGet(1)
    );
    entryThread.start();
}
 
開發者ID:kevin-xu-158,項目名稱:JavaNRPC,代碼行數:50,代碼來源:NrpcServer.java


注:本文中的io.netty.channel.nio.NioEventLoopGroup.shutdownGracefully方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。