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


Java SocketChannel.connect方法代碼示例

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


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

示例1: run

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
private void run() throws Exception
{
	NioThread nt=new NioThread();
	nt.start();
	Thread.sleep(1000);
	SocketChannel sc=SocketChannel.open();
	sc.configureBlocking(false);
	sc.connect(new InetSocketAddress("localhost", 9999));
	ChannelProcessorMultiplexer m=new ChannelProcessorMultiplexer(nt, sc, true,
			VideoServerTCPListener.clientID.getBytes(StandardCharsets.UTF_8),
			VideoServerTCPListener.serverID.getBytes(StandardCharsets.UTF_8));
	DuplexNioConnection conn=new DuplexNioConnection(m);
	m.start();
	CoolRMIClient client=new CoolRMIClient(getClass().getClassLoader(), new RMINioClientConnectionFactory(conn), false);
	Iremote r= (Iremote)client.getService(Iremote.class, Iremote.class.getName());
	System.out.println(""+r.getValue("Kitten"));
	System.out.println(""+r.getValue("Kitten"));
	System.out.println(""+r.getValue("Kitten"));
	System.out.println(""+r.getValue("Kitten"));
}
 
開發者ID:rizsi,項目名稱:rcom,代碼行數:21,代碼來源:RMINioClient.java

示例2: openConnection

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
/**
 * out node try to connect
 *
 * @param node
 */
public void openConnection(Node node) {

    SocketChannel channel = null;
    try {
        channel = SocketChannel.open();
        channel.configureBlocking(false);
        channel.socket().setReuseAddress(true);
        InetSocketAddress socketAddress = new InetSocketAddress(node.getIp(), node.getPort());
        channel.connect(socketAddress);
        PendingConnect data = new PendingConnect(channel, node);
        SelectionKey key = channel.register(selector, SelectionKey.OP_CONNECT);
        key.attach(data);
        selector.wakeup();
    } catch (IOException e) {
        e.printStackTrace();
        if (channel != null) {
            try {
                channel.close();
            } catch (IOException e1) {
                e1.printStackTrace();
            }
        }
        node.destroy();
    }
}
 
開發者ID:nuls-io,項目名稱:nuls,代碼行數:31,代碼來源:ConnectionManager.java

示例3: testStartConnection

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
/**
 * testStartConnection
 */
@Test
public void testStartConnection() throws Exception {
    System.err.println("testStartConnection()");
    for (final HStoreCoordinator m : this.coordinators) {
        // Check that the messenger state is correct
        assert (m.isStarted());

        // Check that the messenger's listener thread is running
        assert (m.getListenerThread().isAlive());

        // Check that we can connect to the messenger's listening port
        int port = m.getLocalMessengerPort();
        SocketChannel channel = SocketChannel.open();
        channel.connect(new InetSocketAddress(port));
        assert (channel.isConnected());
    } // FOR
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:21,代碼來源:TestHStoreCoordinator.java

示例4: connect2

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public static void connect2(Socket socket, 
          SocketAddress endpoint, 
          int timeout) throws IOException {
	  SocketChannel socketChannel = socket.getChannel();
		// ����Ϊ��������ʽ
		socketChannel.configureBlocking(false);
		// ��ѡ����
		Selector selector = Selector.open();
		// ע�����ӷ����socket����
		socketChannel.register(selector, SelectionKey.OP_CONNECT);
		// ����
		socketChannel.connect(endpoint);	 




}
 
開發者ID:spafka,項目名稱:spark_deep,代碼行數:18,代碼來源:NetUtils.java

示例5: run

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
private void run() throws Exception
{
	NioThread nt=new NioThread();
	nt.start();
	Thread.sleep(1000);
	SocketChannel sc=SocketChannel.open();
	sc.configureBlocking(false);
	sc.connect(new InetSocketAddress("localhost", 9999));
	ChannelProcessorMultiplexer m=new ChannelProcessorMultiplexer(nt, sc, true,
			VideoServerTCPListener.clientID.getBytes(StandardCharsets.UTF_8),
			VideoServerTCPListener.serverID.getBytes(StandardCharsets.UTF_8));
	m.start();
	new ConnectToStdout(m);
}
 
開發者ID:rizsi,項目名稱:rcom,代碼行數:15,代碼來源:ExampleNioStdoutClient.java

示例6: registerAndConnect

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
/**
 * register with the selection and connect
 * @param sock the {@link SocketChannel} 
 * @param addr the address of remote host
 * @throws IOException
 */
void registerAndConnect(SocketChannel sock, InetSocketAddress addr) 
throws IOException {
    sockKey = sock.register(selector, SelectionKey.OP_CONNECT);
    boolean immediateConnect = sock.connect(addr);
    if (immediateConnect) {
        sendThread.primeConnection();
    }
}
 
開發者ID:maoling,項目名稱:fuck_zookeeper,代碼行數:15,代碼來源:ClientCnxnSocketNIO.java

示例7: createChannel

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
private SocketChannel createChannel() throws IOException {
    logi(TAG, "Open");
    SocketChannel socketChannel = SocketChannel.open();
    socketChannel.configureBlocking(false);
    socketChannel.connect(getRewrittenDestination());
    return socketChannel;
}
 
開發者ID:Genymobile,項目名稱:gnirehtet,代碼行數:8,代碼來源:TCPConnection.java

示例8: initClient

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public void initClient(String ip, int port) throws IOException { // 獲得一個Socket通道
    SocketChannel channel = SocketChannel.open(); // 設置通道為非阻塞
    channel.configureBlocking(false); // 獲得一個通道管理器
    this.selector = Selector.open(); // 客戶端連接服務器,其實方法執行並沒有實現連接,需要在listen()方法中調
    channel.connect(new InetSocketAddress(ip, port));
    channel.register(selector, SelectionKey.OP_CONNECT);
}
 
開發者ID:laidu,項目名稱:java-learn,代碼行數:8,代碼來源:NioClient.java

示例9: connect

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
public void connect(NioThread nt, SocketAddress address, byte[] thisId, byte[] otherId) throws Exception
{
	SocketChannel sc=SocketChannel.open();
	sc.configureBlocking(false);
	sc.connect(address);
	connect(nt, sc, true, thisId, otherId);
}
 
開發者ID:rizsi,項目名稱:rcom,代碼行數:8,代碼來源:CoolRMINioClient.java

示例10: testConnectCallback

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
@Test
public void testConnectCallback() throws IOException {
    eventLoop.registerAccept(acceptSocket, serverHandler);

    SocketChannel clientSocket = SocketChannel.open();
    clientSocket.configureBlocking(false);
    boolean connected = clientSocket.connect(
            new InetSocketAddress(InetAddress.getLocalHost(), serverPort));
    assertFalse(connected);
    assertTrue(clientSocket.isConnectionPending());
    eventLoop.registerConnect(clientSocket, serverHandler);
    // registering it for reading as well is not permitted: causes problems on Linux
    try {
        eventLoop.registerRead(clientSocket, serverHandler);
        fail("expected exception");
    } catch (AssertionError e) {}

    // The event loop will trigger the accept callback
    assertNull(serverHandler.client);
    eventLoop.runOnce();
    assertNotNull(serverHandler.client);
    assertTrue(clientSocket.isConnectionPending());

    // The event loop will also have triggered the connect callback
    assertTrue(serverHandler.connected);
    connected = clientSocket.finishConnect();
    assertTrue(connected);
    assertTrue(clientSocket.isConnected());

    // Registering some other handler in response to the connect event should work
    eventLoop.registerRead(clientSocket, new TestHandler());

    clientSocket.close();
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:35,代碼來源:NIOEventLoopTest.java

示例11: connect

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
private void connect(Selector selector) {
	Connection c = null;
	while ((c = connectQueue.poll()) != null) {
		try {
			SocketChannel channel = (SocketChannel) c.getChannel();
			//注冊OP_CONNECT監聽與後端連接是否真正建立
			channel.register(selector, SelectionKey.OP_CONNECT, c);
			 //主動連接
			channel.connect(new InetSocketAddress(c.host, c.port));
		} catch (Exception e) {
			LOGGER.error("error:", e);
			c.close("connect failed:" + e.toString());
		}
	}
}
 
開發者ID:variflight,項目名稱:feeyo-redisproxy,代碼行數:16,代碼來源:NIOConnector.java

示例12: run

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
private void run() throws Exception
{
	NioThread nt=new NioThread();
	nt.start();
	Thread.sleep(1000);
	SocketChannel sc=SocketChannel.open();
	sc.configureBlocking(false);
	sc.connect(new InetSocketAddress("localhost", 9999));
	ChannelProcessorMultiplexer m=new ChannelProcessorMultiplexer(nt, sc, true,
			VideoServerTCPListener.clientID.getBytes(StandardCharsets.UTF_8),
			VideoServerTCPListener.serverID.getBytes(StandardCharsets.UTF_8));
	m.start();
	MainChannel mc=new MainChannel();
	mc.register(m);
}
 
開發者ID:rizsi,項目名稱:rcom,代碼行數:16,代碼來源:ExampleNioClient.java

示例13: connect

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
private void connect(Selector finalSelector) {
    AbstractConnection c;
    while ((c = connectQueue.poll()) != null) {
        try {
            SocketChannel channel = (SocketChannel) c.getChannel();
            channel.register(finalSelector, SelectionKey.OP_CONNECT, c);
            channel.connect(new InetSocketAddress(c.host, c.port));

        } catch (Exception e) {
            LOGGER.info("error:", e);
            c.close(e.toString());
        }
    }
}
 
開發者ID:actiontech,項目名稱:dble,代碼行數:15,代碼來源:NIOConnector.java

示例14: handleClients

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
private void handleClients() throws Exception {
    int selectCount = 0;
    while (true) {
        int createdCount = 0;
        synchronized (this) {
            if (connectionsNeeded > 0) {

                while (connectionsNeeded > 0 && createdCount < 20) {
                    connectionsNeeded--;
                    createdCount++;
                    totalCreated++;

                    SocketChannel channel = SocketChannel.open();
                    channel.configureBlocking(false);
                    channel.connect(address);
                    if (!channel.finishConnect()) {
                        channel.register(selector,
                                         SelectionKey.OP_CONNECT);
                    }
                }

                log("Started total of " +
                    totalCreated + " client connections");
                Thread.sleep(200);
            }
        }

        if (createdCount > 0) {
            selector.selectNow();
        } else {
            selectCount++;
            long startTime = System.nanoTime();
            selector.select();
            long duration = durationMillis(startTime);
            log("Exited clientSelector.select(), loop #"
                + selectCount + ", duration = " + duration + "ms");
        }

        int keyCount = -1;
        Iterator<SelectionKey> keys =
            selector.selectedKeys().iterator();
        while (keys.hasNext()) {
            SelectionKey key = keys.next();
            synchronized (key) {
                keyCount++;
                keys.remove();
                if (!key.isValid()) {
                    log("Ignoring client key #" + keyCount);
                    continue;
                }
                int readyOps = key.readyOps();
                if (readyOps == SelectionKey.OP_CONNECT) {
                    key.interestOps(0);
                    ((SocketChannel) key.channel()).finishConnect();
                } else {
                    log("readyOps() on client key #" + keyCount +
                        " returned " + readyOps);
                }
            }
        }
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:63,代碼來源:LotsOfCancels.java

示例15: connect

import java.nio.channels.SocketChannel; //導入方法依賴的package包/類
/**
 * Connect a Session to a server
 * 
 * @param session
 * @throws IOException
 */
void connect(Session session) throws IOException
{
	SocketChannel sChannel = SocketChannel.open();

	sChannel.configureBlocking(false);

	sChannel.connect(new InetSocketAddress(session.getRequestedConnection().getHostName(), session.getRequestedConnection().getPort()));

	sChannel.register(selector, sChannel.validOps());

	Connection con = new Connection(this, sChannel, session);
	session.setConnection(con);

	socChanMap.put(sChannel, session);
}
 
開發者ID:Esri,項目名稱:defense-solutions-proofs-of-concept,代碼行數:22,代碼來源:ConnectionManager.java


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