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


Java AsynchronousSocketChannel類代碼示例

本文整理匯總了Java中java.nio.channels.AsynchronousSocketChannel的典型用法代碼示例。如果您正苦於以下問題:Java AsynchronousSocketChannel類的具體用法?Java AsynchronousSocketChannel怎麽用?Java AsynchronousSocketChannel使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: AioServerConnection

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
public AioServerConnection(AsynchronousSocketChannel channel) {
    this.channel = channel;
    this.reader = new MsgReader(channel) {
        @Override
        protected void onMsg(Msg msg) {
            Command command = MsgConverter.convert(msg);
            Reply reply = commandHandler.handle(command);
            writer.write(reply.toMsg());
        }
    };
    this.writer = new MsgWriter(channel) {
        @Override
        protected void onWriteDone() {
            super.onWriteDone();
            processCommand();
        }
    };
}
 
開發者ID:altiplanogao,項目名稱:io-comparison,代碼行數:19,代碼來源:AioServerConnection.java

示例2: completed

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
/**
 *@description 接收客戶端請求成功之後回調
 *@time 創建時間:2017年7月20日上午11:05:16
 *@param channel
 *@param serverHandler
 *@author dzn
 */
@Override
public void completed(AsynchronousSocketChannel channel,
        AsyncTimeServerHandler serverHandler) {
    
    System.out.println("成功接收到客戶端連接 : " + channel.toString());
    
    //繼續注冊一個接收請求的處理類
    serverHandler.asynchronousServerSocketChannel.accept(serverHandler, this);
    
    //創建一個數據緩衝區
    ByteBuffer bb = ByteBuffer.allocate(1024);
    
    //去讀取客戶端發送的數據,並注冊一個數據處理類
    channel.read(bb, bb, new ReadCompletionHandler(channel));
}
 
開發者ID:SnailFastGo,項目名稱:netty_op,代碼行數:23,代碼來源:AcceptCompletionHandler.java

示例3: make

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
@SuppressWarnings({"unchecked", "rawtypes"})
public MySQLConnection make(MySQLDataSource pool, ResponseHandler handler,
                            String schema) throws IOException {

    DBHostConfig dsc = pool.getConfig();
    NetworkChannel channel = openSocketChannel(DbleServer.getInstance().isAIO());

    MySQLConnection c = new MySQLConnection(channel, pool.isReadNode());
    c.setSocketParams(false);
    c.setHost(dsc.getIp());
    c.setPort(dsc.getPort());
    c.setUser(dsc.getUser());
    c.setPassword(dsc.getPassword());
    c.setSchema(schema);
    c.setHandler(new MySQLConnectionAuthenticator(c, handler));
    c.setPool(pool);
    c.setIdleTimeout(pool.getConfig().getIdleTimeout());
    if (channel instanceof AsynchronousSocketChannel) {
        ((AsynchronousSocketChannel) channel).connect(
                new InetSocketAddress(dsc.getIp(), dsc.getPort()), c,
                (CompletionHandler) DbleServer.getInstance().getConnector());
    } else {
        ((NIOConnector) DbleServer.getInstance().getConnector()).postConnect(c);
    }
    return c;
}
 
開發者ID:actiontech,項目名稱:dble,代碼行數:27,代碼來源:MySQLConnectionFactory.java

示例4: handleNewConnection

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
/**
   * Creates a new client and adds it to the list of connections.
   * Sets the clients handler to the initial state of NameReader
   *
   * @param channel the newly accepted channel
   */
private void handleNewConnection(AsynchronousSocketChannel channel) {
	try {
		channel.setOption(StandardSocketOptions.TCP_NODELAY, true);
	} catch (IOException e) {
		// ignore
		//
		e.printStackTrace();
	}

	//new dealer and channel
	AioServerDataDealer dealer = null;
	
	dealer = aioDataDealerFactory.getAioServerDataDealer();
	
	int channelId = getChannelId();
	AioServerChannel aioChannel = new AioServerChannel(channelId, channel, dealer, this);
	connections.put(channelId, aioChannel);
	
	//start channel
	aioChannel.run(null);
}
 
開發者ID:psfu,項目名稱:waterwave,代碼行數:28,代碼來源:AioServer.java

示例5: setAsynchronousSocketChannel

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
/**
 * @param asynchronousSocketChannel the asynchronousSocketChannel to set
 */
public void setAsynchronousSocketChannel(AsynchronousSocketChannel asynchronousSocketChannel)
{
	this.asynchronousSocketChannel = asynchronousSocketChannel;

	if (asynchronousSocketChannel != null)
	{
		try
		{
			Node clientNode = createClientNode(asynchronousSocketChannel);
			setClientNode(clientNode);
		} catch (IOException e)
		{
			log.info(e.toString(), e);
			assignAnUnknownClientNode();
		}
	} else
	{
		assignAnUnknownClientNode();
	}
}
 
開發者ID:tywo45,項目名稱:talent-aio,代碼行數:24,代碼來源:ChannelContext.java

示例6: retry

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
private void retry() {
    try {
        TimeUnit.SECONDS.sleep(1);
        if (null != this.channel && this.channel.isOpen()) {
            this.channel.close();
        }
        log.debug("連接:{}", this.socketAddress.toString());
        final AsynchronousSocketChannel asynchronousSocketChannel = AsynchronousSocketChannel.open(this.group);
        asynchronousSocketChannel.setOption(StandardSocketOptions.TCP_NODELAY, true);
        asynchronousSocketChannel.setOption(StandardSocketOptions.SO_REUSEADDR, true);
        asynchronousSocketChannel.setOption(StandardSocketOptions.SO_KEEPALIVE, true);
        asynchronousSocketChannel.connect(this.socketAddress).get(5, TimeUnit.SECONDS);
        this.channel = new FastChannel(asynchronousSocketChannel, this.serializer, timeout);
    } catch (final Exception e) {
        retry();
    }
}
 
開發者ID:sd4324530,項目名稱:fastrpc,代碼行數:18,代碼來源:FastRpcClient.java

示例7: acceptCompletionHandler

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
private CompletionHandler<AsynchronousSocketChannel, Integer> acceptCompletionHandler(
			int byteCount, AsynchronousServerSocketChannel socket) {
		return new CompletionHandler<AsynchronousSocketChannel, Integer>() {
			public void completed(
					AsynchronousSocketChannel ch,
					Integer acceptsToGo) {
				acceptsToGo = acceptsToGo-1;
//				System.out.println("server accepted, to go = " + acceptsToGo);
				writeStuffThreadAsync(socket, ch, byteCount, acceptsToGo);
				if (acceptsToGo > 0) {
					socket.accept(acceptsToGo, acceptCompletionHandler(byteCount, socket));
				}
			}
			public void failed(Throwable exc, Integer attachment) {
				exc.printStackTrace();
				try {
					socket.close();
				} catch (IOException e) {
					e.printStackTrace();
				}
			}
		};
	}
 
開發者ID:arienkock,項目名稱:parallelism-benchmarks,代碼行數:24,代碼來源:FountainSocketBenchmark.java

示例8: completed

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
@Override
public void completed(AsynchronousSocketChannel socketChannel, AioServerSocket serverSocket) {
	try {
		//接續接收 accept 請求
		serverSocket.catchAccept();
		
		AioSocket socket = new AioSocket(serverSocket,socketChannel);
		
		//觸發 Accept 事件
		EventTrigger.fireAcceptThread(socket.getSession());
		
		
	} catch (IOException e) {
		EventTrigger.fireExceptionThread(null, e);
	}
}
 
開發者ID:helyho,項目名稱:Voovan,代碼行數:17,代碼來源:AcceptCompletionHandler.java

示例9: main

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
public static void main(String[] args) throws IOException, ExecutionException,
          InterruptedException, TimeoutException {
    //打開 AsychronousServerSocketChannel 並將其綁定到類似於 ServerSocketChannel 的地址
    //方法 bind() 將一個套接字地址作為其參數。找到空閑端口的便利方法是傳遞一個 null 地址,它會自動將套接字綁定到本地主機地址,並使用空閑的 臨時 端口。
    AsynchronousServerSocketChannel server = AsynchronousServerSocketChannel.open().bind(null);
    //告訴通道接受一個連接
    Future<AsynchronousSocketChannel> future = server.accept();

//    利用 Future 對象,當前線程可阻塞來等待結果:
    AsynchronousSocketChannel worker = future.get();
    //超時
    //AsynchronousSocketChannel worker = future.get(10, TimeUnit.SECONDS);
    //取消
//    if (!future.isDone()) {
//      future.cancel(true);//cancel() 方法可利用一個布爾標誌來指出執行接受的線程是否可被中斷
//    }
//
//// read a message from the client
    ByteBuffer readBuffer = ByteBuffer.allocate(1024);
    worker.read(readBuffer).get(10, TimeUnit.SECONDS);
    System.out.println("Message: " + new String(readBuffer.array()));
  }
 
開發者ID:edgar615,項目名稱:javase-study,代碼行數:23,代碼來源:AsynchronousServerSocketMain.java

示例10: Nio2SSLSocket

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
public Nio2SSLSocket(AsynchronousSocketChannel sock, SSLContext sslc, boolean clientMode)
{
	super(sock);
	this.engine = sslc.createSSLEngine();
	this.engine.setUseClientMode(clientMode);
	String[] procols = { "TLSv1" };
	this.engine.setEnabledProtocols(procols);

	int packetBufferSize = engine.getSession().getPacketBufferSize();
	decodeBuf	= ByteBuffer.allocateDirect(packetBufferSize);
	readBuf = ByteBuffer.allocateDirect(packetBufferSize);
	
	for (int i = 0; i < 2; i++)
	{
		writeBufs[i] = ByteBuffer.allocateDirect(packetBufferSize);
		writeBufs[i].limit(0);
	}
	writeBufs[0].clear();
}
 
開發者ID:EricssonResearch,項目名稱:trap,代碼行數:20,代碼來源:Nio2SSLSocket.java

示例11: connect

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
private void connect() throws BindException{
	String errorMessage = "";
	if (socketChannel == null || !socketChannel.isOpen() || closed) {
		try {
			socketChannel = AsynchronousSocketChannel.open();
			socketChannel.setOption(StandardSocketOptions.SO_REUSEADDR, true);
			socketChannel.setOption(StandardSocketOptions.SO_KEEPALIVE, true);
			socketChannel.connect(new InetSocketAddress(ip, port)).get(timeout, TimeUnit.MILLISECONDS);
			closed = false;
			
			//when connect to the server, keep receiving data either server response or server call
			receive();
		} catch (Exception e) {
			log.error("Connection error: " + e.getMessage());
			errorMessage = e.getMessage();
		}
	}
	if (socketChannel == null) {
		throw new BindException(errorMessage);
	}
}
 
開發者ID:zijan,項目名稱:Tatala-RPC,代碼行數:22,代碼來源:LongClientSession.java

示例12: connect

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
private void connect() throws BindException{
	String errorMessage = "";
	if (socketChannel == null || !socketChannel.isOpen() || closed) {
		try {
			socketChannel = AsynchronousSocketChannel.open();
			socketChannel.setOption(StandardSocketOptions.SO_REUSEADDR, true);
			socketChannel.setOption(StandardSocketOptions.SO_KEEPALIVE, true);
			socketChannel.connect(new InetSocketAddress(ip, port)).get(timeout, TimeUnit.MILLISECONDS);
			closed = false;
			log.debug("Session start to " + socketChannel.getRemoteAddress());
			
			//when connect to the server, keep receiving data either server response or server call
			receive();
		} catch (Exception e) {
			log.error("Connection error: " + e.getMessage());
			errorMessage = e.getMessage();
		}
	}
	if (socketChannel == null) {
		throw new BindException(errorMessage);
	}
}
 
開發者ID:zijan,項目名稱:Tatala-RPC,代碼行數:23,代碼來源:LongClientSession.java

示例13: make

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
public MySQLConnection make(MySQLDataSource pool, ResponseHandler handler)
		throws IOException {

	DBHostConfig dsc = pool.getConfig();
	AsynchronousSocketChannel channel = openSocketChannel();
	MySQLConnection c = new MySQLConnection(channel, pool.isReadNode());

	c.setHost(dsc.getIp());
	c.setPort(dsc.getPort());
	c.setUser(dsc.getUser());
	c.setPassword(dsc.getPassword());
	// c.setSchema(dsc.getDatabase());
	c.setHandler(new MySQLConnectionAuthenticator(c, handler));
	c.setPool(pool);
	c.setIdleTimeout(pool.getConfig().getIdleTimeout());
	channel.connect(new InetSocketAddress(dsc.getIp(), dsc.getPort()), c,
			MycatServer.getInstance().getConnector());
	return c;
}
 
開發者ID:youngor,項目名稱:openclouddb,代碼行數:20,代碼來源:MySQLConnectionFactory.java

示例14: SocketSession

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
public SocketSession(AsynchronousSocketChannel channel, ByteBuffer buffer,
		CodecFactory codecFactory) throws IOException {
	this.channel = channel;
	this.remoteAddress = channel.getRemoteAddress();
	this.processor = new Processor(this);
	this.buffer = buffer;
	this.codec = codecFactory.getCodec();
	this.describe = "local:" + channel.getLocalAddress() + " remote:"
			+ remoteAddress + " hashCode/" + super.hashCode();
	this.hashCode = super.hashCode();
	attachment = new ConcurrentHashMap<Object, Object>(128);
	this.attachment.put(MSG_SURPLUS_LENGTH, -1);
	this.attachment.put(MSG_TMP, new byte[0]);
	this.remotePort = Integer.parseInt(this.toString().split(" ")[1]
			.split(":")[2]);
}
 
開發者ID:finikes,項目名稱:tridge,代碼行數:17,代碼來源:SocketSession.java

示例15: AbstractClient

import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
/**
 * Construct a new {@code Client}
 * @param channel that this client listens on
 * @throws IOException If an I/O error occurs
 */
AbstractClient(AsynchronousSocketChannel channel) {
	super();
	this.channel = channel;
	this.cipher = new Cryptographer();
	/*
	 * TODO This option was part of the ChatServer example by Oracle, but
	 * should be used with caution: "The socket option should only be
	 * enabled in cases where it is known that the coalescing impacts
	 * performance". We need to figure out whether it is required to set
	 * this option to true.
	 * 
	 * try {
	 * 	this.channel.setOption(StandardSocketOptions.TCP_NODELAY, true);
	 * } catch (IOException e) {
	 *	e.printStackTrace();
	 * }
	 * 
	 */
}
 
開發者ID:jackpotsvr,項目名稱:Java-Conquer-Server,代碼行數:25,代碼來源:AbstractClient.java


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