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


Java DefaultChannelGroup.add方法代碼示例

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


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

示例1: startUp

import io.netty.channel.group.DefaultChannelGroup; //導入方法依賴的package包/類
@Override
protected void startUp() throws Exception {
  channelGroup = new DefaultChannelGroup(ImmediateEventExecutor.INSTANCE);
  EventLoopGroup bossGroup = new NioEventLoopGroup(NUM_BOSS_THREADS,
                                                   new ThreadFactoryBuilder()
                                                     .setDaemon(true).setNameFormat("boss-thread").build());
  EventLoopGroup workerGroup = new NioEventLoopGroup(NUM_WORKER_THREADS,
                                                     new ThreadFactoryBuilder()
                                                       .setDaemon(true).setNameFormat("worker-thread#%d").build());

  bootstrap = new ServerBootstrap()
    .group(bossGroup, workerGroup)
    .channel(NioServerSocketChannel.class)
    .childHandler(new ChannelInitializer<SocketChannel>() {
      @Override
      protected void initChannel(SocketChannel ch) throws Exception {
        channelGroup.add(ch);
        ChannelPipeline pipeline = ch.pipeline();
        pipeline.addLast("codec", new HttpServerCodec());
        pipeline.addLast("compressor", new HttpContentCompressor());
        pipeline.addLast("aggregator", new HttpObjectAggregator(MAX_INPUT_SIZE));
        pipeline.addLast("handler", new ReportHandler());
      }
    });

  Channel serverChannel = bootstrap.bind(new InetSocketAddress(host, 0)).sync().channel();
  channelGroup.add(serverChannel);

  bindAddress = (InetSocketAddress) serverChannel.localAddress();
  url = URI.create(String.format("http://%s:%d", host, bindAddress.getPort())).toURL();

  LOG.info("Tracker service started at {}", url);
}
 
開發者ID:apache,項目名稱:twill,代碼行數:34,代碼來源:TrackerService.java

示例2: testBindMultiple

import io.netty.channel.group.DefaultChannelGroup; //導入方法依賴的package包/類
/**
 * Test try to reproduce issue #1335
 */
@Test
public void testBindMultiple() throws Exception {
    DefaultChannelGroup channelGroup = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);
    NioEventLoopGroup group = new NioEventLoopGroup();
    try {
        for (int i = 0; i < 100; i++) {
            Bootstrap udpBootstrap = new Bootstrap();
            udpBootstrap.group(group).channel(NioDatagramChannel.class)
                    .option(ChannelOption.SO_BROADCAST, true)
                    .handler(new ChannelInboundHandlerAdapter() {
                        @Override
                        public void channelRead(ChannelHandlerContext ctx, Object msg) {
                            // Discard
                            ReferenceCountUtil.release(msg);
                        }
                    });
            DatagramChannel datagramChannel = (DatagramChannel) udpBootstrap
                    .bind(new InetSocketAddress(0)).syncUninterruptibly().channel();
            channelGroup.add(datagramChannel);
        }
        Assert.assertEquals(100, channelGroup.size());
    } finally {
        channelGroup.close().sync();
        group.shutdownGracefully().sync();
    }
}
 
開發者ID:wuyinxian124,項目名稱:netty4.0.27Learn,代碼行數:30,代碼來源:NioDatagramChannelTest.java

示例3: startServer

import io.netty.channel.group.DefaultChannelGroup; //導入方法依賴的package包/類
@Override
protected void startServer(int port, final Action<ServerWebSocket> websocketAction) {
  bossGroup = new NioEventLoopGroup();
  workerGroup = new NioEventLoopGroup();
  channels = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);
  ServerBootstrap bootstrap = new ServerBootstrap();
  bootstrap.group(bossGroup, workerGroup)
    .channel(NioServerSocketChannel.class)
    .childHandler(new ChannelInitializer<SocketChannel>() {
      @Override
      public void channelActive(ChannelHandlerContext ctx) throws Exception {
        channels.add(ctx.channel());
      }

      @Override
      public void initChannel(SocketChannel ch) throws Exception {
        ChannelPipeline pipeline = ch.pipeline();
        pipeline.addLast(new HttpServerCodec())
        .addLast(new AsityServerCodec() {
          @Override
          protected boolean accept(HttpRequest req) {
            return URI.create(req.getUri()).getPath().equals(TEST_URI);
          }
        }.onwebsocket(websocketAction));
      }
    });
  channels.add(bootstrap.bind(port).channel());
}
 
開發者ID:cettia,項目名稱:asity,代碼行數:29,代碼來源:NettyServerWebSocketTest.java

示例4: startServer

import io.netty.channel.group.DefaultChannelGroup; //導入方法依賴的package包/類
@Override
protected void startServer(int port, final Action<ServerHttpExchange> requestAction) throws
  Exception {
  bossGroup = new NioEventLoopGroup();
  workerGroup = new NioEventLoopGroup();
  channels = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);
  ServerBootstrap bootstrap = new ServerBootstrap();
  bootstrap.group(bossGroup, workerGroup)
    .channel(NioServerSocketChannel.class)
    .childHandler(new ChannelInitializer<SocketChannel>() {
      @Override
      public void channelActive(ChannelHandlerContext ctx) throws Exception {
        channels.add(ctx.channel());
      }

      @Override
      public void initChannel(SocketChannel ch) throws Exception {
        ChannelPipeline pipeline = ch.pipeline();
        pipeline.addLast(new HttpServerCodec())
        .addLast(new AsityServerCodec() {
          @Override
          protected boolean accept(HttpRequest req) {
            return URI.create(req.getUri()).getPath().equals(TEST_URI);
          }
        }.onhttp(requestAction));
      }
    });
  channels.add(bootstrap.bind(port).channel());
}
 
開發者ID:cettia,項目名稱:asity,代碼行數:30,代碼來源:NettyServerHttpExchangeTest.java

示例5: startServer

import io.netty.channel.group.DefaultChannelGroup; //導入方法依賴的package包/類
@Override
protected void startServer() {
    bossGroup = new NioEventLoopGroup();
    workerGroup = new NioEventLoopGroup();
    channels = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);
    ServerBootstrap bootstrap = new ServerBootstrap();
    bootstrap.group(bossGroup, workerGroup)
    .channel(NioServerSocketChannel.class)
    .childHandler(new ChannelInitializer<SocketChannel>() {
        @Override
        public void channelActive(ChannelHandlerContext ctx) throws Exception {
            channels.add(ctx.channel());
        }

        @Override
        public void initChannel(SocketChannel ch) throws Exception {
            ChannelPipeline pipeline = ch.pipeline();
            pipeline.addLast(new HttpServerCodec())
            .addLast(new VibeServerCodec() {
                @Override
                protected boolean accept(HttpRequest req) {
                    return URI.create(req.getUri()).getPath().equals("/test");
                }
            }
            .onwebsocket(performer.serverAction()));
        }
    });
    channels.add(bootstrap.bind(port).channel());
}
 
開發者ID:vibe-project,項目名稱:vibe-java-platform,代碼行數:30,代碼來源:NettyServerWebSocketTest.java

示例6: startServer

import io.netty.channel.group.DefaultChannelGroup; //導入方法依賴的package包/類
@Override
protected void startServer() {
    bossGroup = new NioEventLoopGroup();
    workerGroup = new NioEventLoopGroup();
    channels = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);
    ServerBootstrap bootstrap = new ServerBootstrap();
    bootstrap.group(bossGroup, workerGroup)
    .channel(NioServerSocketChannel.class)
    .childHandler(new ChannelInitializer<SocketChannel>() {
        @Override
        public void channelActive(ChannelHandlerContext ctx) throws Exception {
            channels.add(ctx.channel());
        }

        @Override
        public void initChannel(SocketChannel ch) throws Exception {
            ChannelPipeline pipeline = ch.pipeline();
            pipeline.addLast(new HttpServerCodec())
            .addLast(new VibeServerCodec() {
                @Override
                protected boolean accept(HttpRequest req) {
                    return URI.create(req.getUri()).getPath().equals("/test");
                }
            }
            .onhttp(performer.serverAction()));
        }
    });
    channels.add(bootstrap.bind(port).channel());
}
 
開發者ID:vibe-project,項目名稱:vibe-java-platform,代碼行數:30,代碼來源:NettyServerHttpExchangeTest.java

示例7: testBindMultiple

import io.netty.channel.group.DefaultChannelGroup; //導入方法依賴的package包/類
/**
 * Test try to reproduce issue #1335
 */
@Test
public void testBindMultiple() throws Exception {
    DefaultChannelGroup channelGroup = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);
    NioEventLoopGroup group = new NioEventLoopGroup();
    try {
        for (int i = 0; i < 100; i++) {
            Bootstrap udpBootstrap = new Bootstrap();
            udpBootstrap.group(group).channel(NioDatagramChannel.class)
                    .option(ChannelOption.SO_BROADCAST, true)
                    .handler(new ChannelHandlerAdapter() {
                        @Override
                        public void channelRead(ChannelHandlerContext ctx, Object msg) {
                            // Discard
                            ReferenceCountUtil.release(msg);
                        }
                    });
            DatagramChannel datagramChannel = (DatagramChannel) udpBootstrap
                    .bind(new InetSocketAddress(0)).syncUninterruptibly().channel();
            channelGroup.add(datagramChannel);
        }
        Assert.assertEquals(100, channelGroup.size());
    } finally {
        channelGroup.close().sync();
        group.shutdownGracefully().sync();
    }
}
 
開發者ID:nathanchen,項目名稱:netty-netty-5.0.0.Alpha1,代碼行數:30,代碼來源:NioDatagramChannelTest.java

示例8: bootstrapNetty

import io.netty.channel.group.DefaultChannelGroup; //導入方法依賴的package包/類
/**
 * Bootstraps netty, the server that handles all openflow connections
 */
public void bootstrapNetty() {
	try {
		bossGroup = new NioEventLoopGroup();
		workerGroup = new NioEventLoopGroup();

		ServerBootstrap bootstrap = new ServerBootstrap()
		.group(bossGroup, workerGroup)
		.channel(NioServerSocketChannel.class)
		.option(ChannelOption.SO_REUSEADDR, true)
		.option(ChannelOption.SO_KEEPALIVE, true)
		.option(ChannelOption.TCP_NODELAY, true)
		.option(ChannelOption.SO_SNDBUF, Controller.SEND_BUFFER_SIZE);


		OFChannelInitializer initializer = new OFChannelInitializer(
				this, 
				this, 
				debugCounterService, 
				floodlightProvider.getTimer(), 
				ofBitmaps, 
				defaultFactory, 
				keyStore, 
				keyStorePassword);

		bootstrap.childHandler(initializer);

		cg = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);

		Set<InetSocketAddress> addrs = new HashSet<InetSocketAddress>();
		if (floodlightProvider.getOFAddresses().isEmpty()) {
			cg.add(bootstrap.bind(new InetSocketAddress(InetAddress.getByAddress(IPv4Address.NONE.getBytes()), floodlightProvider.getOFPort().getPort())).channel());
		} else {
			for (IPv4Address ip : floodlightProvider.getOFAddresses()) {
				addrs.add(new InetSocketAddress(InetAddress.getByAddress(ip.getBytes()), floodlightProvider.getOFPort().getPort()));
			}
		}
		
		for (InetSocketAddress sa : addrs) {
			cg.add(bootstrap.bind(sa).channel());
			log.info("Listening for switch connections on {}", sa);
		}

	} catch (Exception e) {
		throw new RuntimeException(e);
	}
}
 
開發者ID:xuraylei,項目名稱:fresco_floodlight,代碼行數:50,代碼來源:OFSwitchManager.java

示例9: bootstrapNetty

import io.netty.channel.group.DefaultChannelGroup; //導入方法依賴的package包/類
/**
 * Bootstraps netty, the server that handles all openflow connections
 */
public void bootstrapNetty() {
	try {
		bossGroup = new NioEventLoopGroup();
		workerGroup = new NioEventLoopGroup();

		ServerBootstrap bootstrap = new ServerBootstrap()
		.group(bossGroup, workerGroup)
		.channel(NioServerSocketChannel.class)
		.option(ChannelOption.SO_REUSEADDR, true)
		.option(ChannelOption.SO_KEEPALIVE, true)
		.option(ChannelOption.TCP_NODELAY, true)
		.option(ChannelOption.SO_SNDBUF, Controller.SEND_BUFFER_SIZE);


		OFChannelInitializer initializer = new OFChannelInitializer(
				this,
				this,
				debugCounterService,
				floodlightProvider.getTimer(),
				ofBitmaps,
				defaultFactory,
				keyStore,
				keyStorePassword);

		bootstrap.childHandler(initializer);

		cg = new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);

		Set<InetSocketAddress> addrs = new HashSet<InetSocketAddress>();
		if (floodlightProvider.getOFAddresses().isEmpty()) {
			cg.add(bootstrap.bind(new InetSocketAddress(InetAddress.getByAddress(IPv4Address.NONE.getBytes()), floodlightProvider.getOFPort().getPort())).channel());
		} else {
			for (IPv4Address ip : floodlightProvider.getOFAddresses()) {
				addrs.add(new InetSocketAddress(InetAddress.getByAddress(ip.getBytes()), floodlightProvider.getOFPort().getPort()));
			}
		}

		for (InetSocketAddress sa : addrs) {
			cg.add(bootstrap.bind(sa).channel());
			log.info("Listening for switch connections on {}", sa);
		}

	} catch (Exception e) {
		throw new RuntimeException(e);
	}
}
 
開發者ID:zhenshengcai,項目名稱:floodlight-hardware,代碼行數:50,代碼來源:OFSwitchManager.java


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