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


Java ChannelGroup.add方法代碼示例

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


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

示例1: bootstrapNetty

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
/**
 * Bootstraps netty, the server that handles all openflow connections
 */
public void bootstrapNetty() {
	try {
		final ServerBootstrap bootstrap = createServerBootStrap();

		bootstrap.setOption("reuseAddr", true);
		bootstrap.setOption("child.keepAlive", true);
		bootstrap.setOption("child.tcpNoDelay", true);
		bootstrap.setOption("child.sendBufferSize", Controller.SEND_BUFFER_SIZE);

		ChannelPipelineFactory pfact = useSsl ? new OpenflowPipelineFactory(this, floodlightProvider.getTimer(), this, debugCounterService, keyStore, keyStorePassword) :
			new OpenflowPipelineFactory(this, floodlightProvider.getTimer(), this, debugCounterService);

		bootstrap.setPipelineFactory(pfact);
		InetSocketAddress sa = new InetSocketAddress(floodlightProvider.getOFPort());
		final ChannelGroup cg = new DefaultChannelGroup();
		cg.add(bootstrap.bind(sa));

		log.info("Listening for switch connections on {}", sa);
	} catch (Exception e) {
		throw new RuntimeException(e);
	}
}
 
開發者ID:nsg-ethz,項目名稱:iTAP-controller,代碼行數:26,代碼來源:OFSwitchManager.java

示例2: bootstrapNetty

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
/**
 * Bootstraps netty, the server that handles all openflow connections
 */
public void bootstrapNetty() {
	try {
		final ServerBootstrap bootstrap = createServerBootStrap();

		bootstrap.setOption("reuseAddr", true);
		bootstrap.setOption("child.keepAlive", true);
		bootstrap.setOption("child.tcpNoDelay", true);
		bootstrap.setOption("child.sendBufferSize", Controller.SEND_BUFFER_SIZE);
		
		ChannelPipelineFactory pfact = useSsl ? new OpenflowPipelineFactory(this, floodlightProvider.getTimer(), this, debugCounterService, ofBitmaps, defaultFactory, keyStore, keyStorePassword) :
			new OpenflowPipelineFactory(this, floodlightProvider.getTimer(), this, debugCounterService, ofBitmaps, defaultFactory);
		
		bootstrap.setPipelineFactory(pfact);
		InetSocketAddress sa = new InetSocketAddress(floodlightProvider.getOFPort());
		final ChannelGroup cg = new DefaultChannelGroup();
		cg.add(bootstrap.bind(sa));

		log.info("Listening for switch connections on {}", sa);
	} catch (Exception e) {
		throw new RuntimeException(e);
	}
}
 
開發者ID:rhoybeen,項目名稱:floodlightLB,代碼行數:26,代碼來源:OFSwitchManager.java

示例3: bootstrapNetty

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
/**
 * Bootstraps netty, the server that handles all openflow connections
 * 啟動netty,處理所有OF連接
 */
public void bootstrapNetty() {
	try {
		final ServerBootstrap bootstrap = createServerBootStrap();

		bootstrap.setOption("reuseAddr", true);
		bootstrap.setOption("child.keepAlive", true);
		bootstrap.setOption("child.tcpNoDelay", true);
		bootstrap.setOption("child.sendBufferSize", Controller.SEND_BUFFER_SIZE);

		ChannelPipelineFactory pfact = useSsl ? new OpenflowPipelineFactory(this, floodlightProvider.getTimer(), this, debugCounterService, keyStore, keyStorePassword) :
			new OpenflowPipelineFactory(this, floodlightProvider.getTimer(), this, debugCounterService);

		bootstrap.setPipelineFactory(pfact);
		InetSocketAddress sa = new InetSocketAddress(floodlightProvider.getOFPort());
		final ChannelGroup cg = new DefaultChannelGroup();
		cg.add(bootstrap.bind(sa));

		log.info("Listening for switch connections on {}", sa);
	} catch (Exception e) {
		throw new RuntimeException(e);
	}
}
 
開發者ID:DaiDongLiang,項目名稱:DSC,代碼行數:27,代碼來源:OFSwitchManager.java

示例4: bootstrapNetty

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
/**
 * Bootstraps netty, the server that handles all openflow connections
 */
public void bootstrapNetty() {
	try {
		final ServerBootstrap bootstrap = createServerBootStrap();

		bootstrap.setOption("reuseAddr", true);
		bootstrap.setOption("child.keepAlive", true);
		bootstrap.setOption("child.tcpNoDelay", true);
		bootstrap.setOption("child.sendBufferSize", Controller.SEND_BUFFER_SIZE);

		ChannelPipelineFactory pfact =
				new OpenflowPipelineFactory(this, floodlightProvider.getTimer(), this, debugCounterService);
		bootstrap.setPipelineFactory(pfact);
		InetSocketAddress sa = new InetSocketAddress(floodlightProvider.getOFPort());
		final ChannelGroup cg = new DefaultChannelGroup();
		cg.add(bootstrap.bind(sa));

		log.info("Listening for switch connections on {}", sa);
	} catch (Exception e) {
		throw new RuntimeException(e);
	}
}
 
開發者ID:pixuan,項目名稱:floodlight,代碼行數:25,代碼來源:OFSwitchManager.java

示例5: withoutPacketTest

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
@Test
public void withoutPacketTest() throws Exception {
    ChannelGroup channelGroup = new DefaultChannelGroup();

    HealthCheckManager healthCheckManager = new HealthCheckManager(timer, 3000, channelGroup);
    healthCheckManager.start(1000);

    Channel mockChannel = createMockChannel(HealthCheckState.WAIT);
    channelGroup.add(mockChannel);

    try {
        verify(mockChannel, timeout(5000).atLeastOnce()).close();
    } finally {
        healthCheckManager.stop();
    }
}
 
開發者ID:naver,項目名稱:pinpoint,代碼行數:17,代碼來源:HealthCheckManagerTest.java

示例6: HttpTunnelServerChannel

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
protected HttpTunnelServerChannel(ChannelFactory factory, ChannelPipeline pipeline, ChannelSink sink, ServerSocketChannelFactory inboundFactory, ChannelGroup realConnections) {
	super(factory, pipeline, sink);

	tunnelIdPrefix = Long.toHexString(random.nextLong());
	tunnels = new ConcurrentHashMap<String, HttpTunnelAcceptedChannel>();

	config = new HttpTunnelServerChannelConfig();
	realChannel = inboundFactory.newChannel(this.createRealPipeline(realConnections));
	config.setRealChannel(realChannel);

	opened = new AtomicBoolean(true);
	bindState = new AtomicReference<BindState>(BindState.UNBOUND);

	realConnections.add(realChannel);

	Channels.fireChannelOpen(this);
}
 
開發者ID:reines,項目名稱:httptunnel,代碼行數:18,代碼來源:HttpTunnelServerChannel.java

示例7: legacyPingPacketTest

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
@Test
public void legacyPingPacketTest() throws Exception {
    ChannelGroup channelGroup = new DefaultChannelGroup();

    HealthCheckManager healthCheckManager = new HealthCheckManager(timer, 3000, channelGroup);
    healthCheckManager.start(1000);

    Channel mockChannel = createMockChannel(HealthCheckState.RECEIVED_LEGACY);
    channelGroup.add(mockChannel);
    try {
        verify(mockChannel, timeout(3000).atLeastOnce()).write(PingPacket.PING_PACKET);
    } finally {
        healthCheckManager.stop();
    }
}
 
開發者ID:naver,項目名稱:pinpoint,代碼行數:16,代碼來源:HealthCheckManagerTest.java

示例8: pingPacketTest

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
@Test
public void pingPacketTest() throws Exception {
    ChannelGroup channelGroup = new DefaultChannelGroup();

    HealthCheckManager healthCheckManager = new HealthCheckManager(timer, 3000, channelGroup);
    healthCheckManager.start(1000);

    Channel mockChannel = createMockChannel(HealthCheckState.RECEIVED);
    channelGroup.add(mockChannel);
    try {
        verify(mockChannel, timeout(3000).atLeastOnce()).write(PingSimplePacket.PING_PACKET);
    } finally {
        healthCheckManager.stop();
    }
}
 
開發者ID:naver,項目名稱:pinpoint,代碼行數:16,代碼來源:HealthCheckManagerTest.java

示例9: initHttpBootstrap

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
private void initHttpBootstrap(int myport) {
	logger.info("initHttpBootstrap...........");
	final ServerConfig serverConfig = new ServerConfig(myport);
	final ChannelGroup channelGroup = new DefaultChannelGroup(getClass().getName());
	bootstrap = new ServerBootstrap(new NioServerSocketChannelFactory(
			//建議用ThreadPoolExecutor代替
			Executors.newCachedThreadPool(),
			Executors.newCachedThreadPool(), serverConfig.getThreadCnt()));
	//設置常見參數
	bootstrap.setOption("tcpNoDelay","true");//禁用nagle算法
	bootstrap.setOption("reuseAddress", "true");
	bootstrap.setOption("SO_RCVBUF",1024*128);
	bootstrap.setOption("SO_SNDBUF",1024*128);
	timer = new HashedWheelTimer();
	bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
		public ChannelPipeline getPipeline() throws Exception {
			ChannelPipeline pipeline = Channels.pipeline();
			int readTimeout = serverConfig.getReadTimeout();
			if (readTimeout > 0) {
				pipeline.addLast("timeout", new ReadTimeoutHandler(timer, readTimeout, TimeUnit.MILLISECONDS));
			}
			pipeline.addLast("decoder", new RpcRequestDecode());
			pipeline.addLast("encoder", new RpcResponseEncode());
			pipeline.addLast("handler", new NettyRpcServerHandler(channelGroup));
			return pipeline;
		}
	});
	
	int port = serverConfig.getPort();
	if (!checkPortConfig(port)) {
		throw new IllegalStateException("port: " + port + " already in use!");
	}

	Channel channel = bootstrap.bind(new InetSocketAddress(port));
	channelGroup.add(channel);
	logger.info("voyage server started");

	waitForShutdownCommand();
	ChannelGroupFuture future = channelGroup.close();
	future.awaitUninterruptibly();
	bootstrap.releaseExternalResources();
	timer.stop();
	timer = null;

	logger.info("voyage server stoped");

}
 
開發者ID:zhaoshiling1017,項目名稱:voyage,代碼行數:48,代碼來源:RpcServerBootstrap.java

示例10: addSubscription

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
public void addSubscription( String path, Channel channel ) {
    ChannelGroup group = subscribers.get( path );
    synchronized ( group ) {
        group.add( channel );
    }
}
 
開發者ID:apache,項目名稱:usergrid,代碼行數:7,代碼來源:WebSocketChannelHandler.java

示例11: HttpTunnelClientChannel

import org.jboss.netty.channel.group.ChannelGroup; //導入方法依賴的package包/類
/**
 * @see HttpTunnelClientChannelFactory#newChannel(ChannelPipeline)
 */
protected HttpTunnelClientChannel(ChannelFactory factory, ChannelPipeline pipeline, HttpTunnelClientChannelSink sink, ClientSocketChannelFactory outboundFactory, ChannelGroup realConnections) {
	super(null, factory, pipeline, sink);

	this.outboundFactory = outboundFactory;

	final WorkerCallbacks callbackProxy = new WorkerCallbacks();

	incomingBuffer = new IncomingBuffer<ChannelBuffer>(this);

	Metrics.newGauge(HttpTunnelClientChannel.class, "incomingBuffer", new Gauge<Integer>() {
	    @Override
	    public Integer value() {
	        return incomingBuffer.size();
	    }
	});

	sendChannel = outboundFactory.newChannel(Channels.pipeline(new SimpleChannelHandler()));
	pollChannel = outboundFactory.newChannel(Channels.pipeline(new SimpleChannelHandler()));

	config = new HttpTunnelClientChannelConfig(sendChannel.getConfig(), pollChannel.getConfig());
	saturationManager = new SaturationManager(config.getWriteBufferLowWaterMark(), config.getWriteBufferHighWaterMark());

	sendHttpHandler = new HttpTunnelClientChannelProxyHandler();
	sendHandler = new HttpTunnelClientChannelSendHandler(callbackProxy);

	pollHttpHandler = new HttpTunnelClientChannelProxyHandler();
	pollHandler = new HttpTunnelClientChannelPollHandler(callbackProxy);

	opened = new AtomicBoolean(true);
	bindState = new AtomicReference<BindState>(BindState.UNBOUND);
	connectState = new AtomicReference<ConnectState>(ConnectState.DISCONNECTED);
	connectFuture = new AtomicReference<ChannelFuture>(null);

	tunnelId = null;
	remoteAddress = null;

	this.initSendPipeline(sendChannel.getPipeline());
	this.initPollPipeline(pollChannel.getPipeline());

	realConnections.add(sendChannel);
	realConnections.add(pollChannel);

	Channels.fireChannelOpen(this);
}
 
開發者ID:reines,項目名稱:httptunnel,代碼行數:48,代碼來源:HttpTunnelClientChannel.java


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