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


Java ClientBootstrap.releaseExternalResources方法代碼示例

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


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

示例1: run

import org.jboss.netty.bootstrap.ClientBootstrap; //導入方法依賴的package包/類
public void run() {
  // Configure the client.
  ChannelFactory factory = new NioClientSocketChannelFactory(
      Executors.newCachedThreadPool(), Executors.newCachedThreadPool(), 1, 1);
  ClientBootstrap bootstrap = new ClientBootstrap(factory);

  // Set up the pipeline factory.
  bootstrap.setPipelineFactory(setPipelineFactory());

  bootstrap.setOption("tcpNoDelay", true);
  bootstrap.setOption("keepAlive", true);

  // Start the connection attempt.
  ChannelFuture future = bootstrap.connect(new InetSocketAddress(host, port));

  if (oneShot) {
    // Wait until the connection is closed or the connection attempt fails.
    future.getChannel().getCloseFuture().awaitUninterruptibly();

    // Shut down thread pools to exit.
    bootstrap.releaseExternalResources();
  }
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:24,代碼來源:SimpleTcpClient.java

示例2: prepare

import org.jboss.netty.bootstrap.ClientBootstrap; //導入方法依賴的package包/類
public void prepare(Map stormConf, TopologyContext context,
        			final OutputCollector collector) {
	_collector = collector;
	ChannelFactory factory = new NioClientSocketChannelFactory(
									Executors.newCachedThreadPool(),
									Executors.newCachedThreadPool());
	_bootstrap = new ClientBootstrap(factory);
	
	_bootstrap.setPipelineFactory(getPipelineFactory());
	_bootstrap.setOptions(_options);
	
    ChannelFuture future = _bootstrap.connect(new InetSocketAddress(_host, _port));
    
    int connectTimeout = DEFAULT_CONNECT_TIMEOUT;
       Object connectTimeoutConfig = stormConf.get(Config.NIMBUS_TASK_LAUNCH_SECS);
       if (connectTimeoutConfig != null) {
       	connectTimeout = ((Number)connectTimeoutConfig).intValue()*1000/2;
       }
       
    future.awaitUninterruptibly(connectTimeout);
    if (!future.isSuccess()) {
    	_bootstrap.releaseExternalResources();
    	throw new RuntimeException("Could not connect to '"+_host+":"+_port, future.getCause());
    }
    _channel = future.getChannel();  
}
 
開發者ID:danigiri,項目名稱:storm-sockets,代碼行數:27,代碼來源:SocketBolt.java

示例3: createChannel

import org.jboss.netty.bootstrap.ClientBootstrap; //導入方法依賴的package包/類
/**
 * Creates a new channel to given host and port.<br>
 *
 * @param host
 * @param port
 * @return
 * @throws Exception
 */
private Channel createChannel(String host, int port) throws Exception {
    // Important notice; use NioClientSocketChannelFactory instead
    // of NioServerSocketChannelFactory
    ChannelFactory channelFactory = new NioClientSocketChannelFactory(
            Executors.newCachedThreadPool(),
            Executors.newCachedThreadPool());
    ClientBootstrap bootstrap = new ClientBootstrap(channelFactory);
    //bootstrap.setPipelineFactory(new SipClientPipelineFactory(false,false));
    bootstrap.setPipelineFactory(new SipPipelineFactory(sipServerHandler));
    ChannelFuture future = bootstrap.connect(new InetSocketAddress(host, port));

    // open / connect to channel
    Channel c = future.await().getChannel();
    if (!future.isSuccess()) {
        log.warn(String.format("createChannel. Establishing connection failed[%s]",
                future.getCause().getMessage()));
        bootstrap.releaseExternalResources();
    }
    return c;
}
 
開發者ID:elasticsoftwarefoundation,項目名稱:elasterix,代碼行數:29,代碼來源:SipChannelFactoryImpl.java

示例4: connect

import org.jboss.netty.bootstrap.ClientBootstrap; //導入方法依賴的package包/類
public void connect(){

		bootstrap = new ClientBootstrap( new NioClientSocketChannelFactory(
				Executors.newCachedThreadPool(),
				Executors.newCachedThreadPool()));
		bootstrap.setOption("tcpNoDelay", false);
		bootstrap.setOption("keepAlive", true);

		final NettyClientHandler handler = new NettyClientHandler(this, timer);
		
		bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
			
			public ChannelPipeline getPipeline() throws Exception {
				ChannelPipeline pipeline =  Channels.pipeline();
				pipeline.addLast("handler", handler);

				if(openCompression){
                    pipeline.addLast("zlibEncoder", new ZlibEncoder(ZlibWrapper.GZIP, compressionLevel));
                }

				if (isFlowControl) {
					logger.debug("flowControl,flowThreshold={}", flowThreshold);
					pipeline.addLast("flowControl", new FLowControlHandler(flowThreshold));
				}

                pipeline.addLast("encoder", new StringEncoder());
				return pipeline;
			}
		});
		
		bootstrap.setOption("remoteAddress", new InetSocketAddress(host, port));
		try {
			ChannelFuture future = bootstrap.connect().sync();
			channel = future.getChannel();
		} catch (Exception e) {
			logger.error("", e);
			bootstrap.releaseExternalResources();
			System.exit(-1);//第一次連接出現異常直接退出,不走重連
		}
	}
 
開發者ID:DTStack,項目名稱:jlogstash-output-plugin,代碼行數:41,代碼來源:Netty.java

示例5: connect

import org.jboss.netty.bootstrap.ClientBootstrap; //導入方法依賴的package包/類
public void connect(){

		bootstrap = new ClientBootstrap( new NioClientSocketChannelFactory(
				Executors.newCachedThreadPool(),
				Executors.newCachedThreadPool()));
		bootstrap.setOption("tcpNoDelay", false);
		bootstrap.setOption("keepAlive", true);

		final NettyClientHandler handler = new NettyClientHandler(this, timer);
		
		bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
			
			public ChannelPipeline getPipeline() throws Exception {
				ChannelPipeline pipeline =  Channels.pipeline();
				pipeline.addLast("handler", handler);
				pipeline.addLast("encoder", new StringEncoder());
				return pipeline;
			}
		});
		
		bootstrap.setOption("remoteAddress", new InetSocketAddress(host, port));
		try {
			ChannelFuture future = bootstrap.connect().sync();
			channel = future.getChannel();
		} catch (Exception e) {
			logger.error(ExceptionUtil.getErrorMessage(e));
			bootstrap.releaseExternalResources();
			System.exit(-1);//第一次連接出現異常直接退出,不走重連
		}
	}
 
開發者ID:DTStack,項目名稱:jlogstash-input-plugin,代碼行數:31,代碼來源:NettySend.java

示例6: establishConnection

import org.jboss.netty.bootstrap.ClientBootstrap; //導入方法依賴的package包/類
protected void establishConnection() throws IOException
{
    // Configure the client.
    bootstrap = new ClientBootstrap(
                    new NioClientSocketChannelFactory(
                        Executors.newCachedThreadPool(),
                        Executors.newCachedThreadPool()));

    bootstrap.setOption("tcpNoDelay", true);

    // Configure the pipeline factory.
    if(encryptionOptions.enabled)
    {
        bootstrap.setPipelineFactory(new SecurePipelineFactory());
    }
    else
    {
        bootstrap.setPipelineFactory(new PipelineFactory());
    }
    ChannelFuture future = bootstrap.connect(new InetSocketAddress(host, port));

    // Wait until the connection attempt succeeds or fails.
    channel = future.awaitUninterruptibly().getChannel();
    if (!future.isSuccess())
    {
        bootstrap.releaseExternalResources();
        throw new IOException("Connection Error", future.getCause());
    }
}
 
開發者ID:pgaref,項目名稱:ACaZoo,代碼行數:30,代碼來源:SimpleClient.java

示例7: main

import org.jboss.netty.bootstrap.ClientBootstrap; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    // Print usage if no argument is specified.
    if (args.length != 2) {
        System.err.println(
                "Usage: " + ChatClient.class.getSimpleName() +
                " <host> <port> ");
        return;
    }

    // Parse options.
    final String host = args[0];
    final int port = Integer.parseInt(args[1]);

    // Configure the client.
    ClientBootstrap bootstrap = new ClientBootstrap(
            new NioClientSocketChannelFactory(
                    Executors.newCachedThreadPool(),
                    Executors.newCachedThreadPool()));

    // Set up the pipeline factory.
    bootstrap.setPipelineFactory(new ChatClientPipelineFactory());

    // Start the connection attempt.
    ChannelFuture future = bootstrap.connect(new InetSocketAddress(host, port));

    // Wait until the connection is closed or the connection attempt fails.
    future.getChannel().getCloseFuture().awaitUninterruptibly();

    // Shut down thread pools to exit.
    bootstrap.releaseExternalResources();
}
 
開發者ID:whg333,項目名稱:nettyProtobufChat,代碼行數:32,代碼來源:ChatClient.java

示例8: connect

import org.jboss.netty.bootstrap.ClientBootstrap; //導入方法依賴的package包/類
private boolean connect(){
//     socket = new Socket("192.168.20.12", 8085);
//     System.out.println("socket connect success!");
//     reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
//     writer = new BufferedWriter(new OutputStreamWriter(socket.getOutputStream()));
            
        bootstrap = new ClientBootstrap(
                new NioClientSocketChannelFactory(
                        Executors.newCachedThreadPool(),
                        Executors.newCachedThreadPool()));

        // Set up the pipeline factory.
        bootstrap.setPipelineFactory(new ChannelPipelineFactory(){
        	public ChannelPipeline getPipeline(){
        		return pipeline(
        		        new LengthFieldBasedFrameDecoder(max_frame_length_8kb, 0, frame_length_4b, 0, frame_length_4b, true, true),
        		        new ChatProtoBufDecoder(),
        		        new ChatProtoBufEncoder(),
        		        new ChatClientGuiHandler()
        		);
        	}
        });

        // Start the connection attempt.
        SocketAddress address = new InetSocketAddress(ipFiled.getText(), Integer.parseInt(portFiled.getText()));
        ChannelFuture future = bootstrap.connect(address);
        channel = future.awaitUninterruptibly().getChannel();
        if (!future.isSuccess()) {
            future.getCause().printStackTrace();
            bootstrap.releaseExternalResources();
			return false;
        }
        
        return true;
	}
 
開發者ID:whg333,項目名稱:nettyProtobufChat,代碼行數:36,代碼來源:ChatClientGui.java

示例9: request

import org.jboss.netty.bootstrap.ClientBootstrap; //導入方法依賴的package包/類
public void request() throws Exception {
    
    // Parse options.
    String host = "localhost";
    int port = 10081;
    int connectTimeoutMillis = 2000;
    // Configure the client.
    ClientBootstrap bootstrap = new ClientBootstrap(
            new NioClientSocketChannelFactory(
                    Executors.newCachedThreadPool(),
                    Executors.newCachedThreadPool()));

    final TelnetClientHandler handler = new TelnetClientHandler();

    // Configure the pipeline factory.
    bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
        public ChannelPipeline getPipeline() {
            ChannelPipeline pipeline = Channels.pipeline();
            pipeline.addLast("framer", new DelimiterBasedFrameDecoder(1024,
                    Delimiters.lineDelimiter()));
            pipeline.addLast("stringDecoder", stringDecoder);
            pipeline.addLast("stringEncoder", stringEncoder);
            pipeline.addLast("handler", handler);
            return pipeline;
        }
    });
    
    
    bootstrap.setOption("connectTimeoutMillis",connectTimeoutMillis);
    bootstrap.setOption("tcpNoDelay", true);
    bootstrap.setOption("keepAlive", true);
    // Start the connection attempt.
    ChannelFuture future = bootstrap.connect(new InetSocketAddress(host,
            port));

    // Wait until the connection attempt succeeds or fails.
    Channel channel = future.awaitUninterruptibly().getChannel();
    // Read commands from the stdin.
    ChannelFuture lastWriteFuture = null;
    String command = "hadoopMonitorFromClient";

    // Sends the line to server.
    lastWriteFuture = channel.write(command + "\r\n");

    // Wait until all messages are flushed before closing the channel.
    if (lastWriteFuture != null) {
        lastWriteFuture.await();
    }

    // note that we need to wait for the response before

    // wait time before close the channel too early that msg will not be
    // received.

    while (!handler.channelCompleted) {
        Thread.sleep(1l);
    }

    // Close the connection. Make sure the close operation ends because
    // all I/O operations are asynchronous in Netty.
    channel.close().awaitUninterruptibly();
    // Shut down all thread pools to exit.
    bootstrap.releaseExternalResources();
    
}
 
開發者ID:eBay,項目名稱:parallec,代碼行數:66,代碼來源:TcpProviderPoc.java

示例10: remoteCapiConnect

import org.jboss.netty.bootstrap.ClientBootstrap; //導入方法依賴的package包/類
public static Channel remoteCapiConnect(InetSocketAddress remoteAddress, ChannelHandler handler) {

        ChannelFuture connectFuture = null;

        // configure client bootstrap
        final ClientBootstrap bootstrap = new ClientBootstrap(new NioClientSocketChannelFactory(Executors
                .newCachedThreadPool(), Executors.newCachedThreadPool()));

        try {

            // use Request-Response handler business logic
            bootstrap.setPipelineFactory(new RemoteCapiPipelineFactory(handler));

            // start the connection attempt
            connectFuture = bootstrap.connect(remoteAddress);

            connectFuture.await(CONNECT_TIMEOUT_SECONDS, TimeUnit.SECONDS);

        } catch (InterruptedException e) {
            return null;
        } finally {
            if (connectFuture.isSuccess()) {
                // shut down thread pools on channelClosed
                connectFuture.getChannel().getCloseFuture().addListener(new ChannelFutureListener() {
                    public void operationComplete(ChannelFuture closeFuture) throws Exception {
                    	new Thread() {
                    		@Override
                    		public void run() {
                                bootstrap.releaseExternalResources();
                    		}
                    	}.start();
                    }
                });
            } else {
                // shut down thread pools due to connection failure
                bootstrap.releaseExternalResources();

                return null;
            }
        }

        return connectFuture.getChannel();
    }
 
開發者ID:rmarins,項目名稱:netty-isdn-transport,代碼行數:44,代碼來源:RemoteCapiHelper.java


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