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


Java Socket.setSoTimeout方法代碼示例

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


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

示例1: connectToDN

import java.net.Socket; //導入方法依賴的package包/類
/**
 * Connect to the given datanode's datantrasfer port, and return
 * the resulting IOStreamPair. This includes encryption wrapping, etc.
 */
public static IOStreamPair connectToDN(DatanodeInfo dn, int timeout,
                                       Configuration conf,
                                       SaslDataTransferClient saslClient,
                                       SocketFactory socketFactory,
                                       boolean connectToDnViaHostname,
                                       DataEncryptionKeyFactory dekFactory,
                                       Token<BlockTokenIdentifier> blockToken)
    throws IOException {

  boolean success = false;
  Socket sock = null;
  try {
    sock = socketFactory.createSocket();
    String dnAddr = dn.getXferAddr(connectToDnViaHostname);
    LOG.debug("Connecting to datanode {}", dnAddr);
    NetUtils.connect(sock, NetUtils.createSocketAddr(dnAddr), timeout);
    sock.setSoTimeout(timeout);

    OutputStream unbufOut = NetUtils.getOutputStream(sock);
    InputStream unbufIn = NetUtils.getInputStream(sock);
    IOStreamPair pair = saslClient.newSocketSend(sock, unbufOut,
        unbufIn, dekFactory, blockToken, dn);

    IOStreamPair result = new IOStreamPair(
        new DataInputStream(pair.in),
        new DataOutputStream(new BufferedOutputStream(pair.out,
            NuCypherExtUtilClient.getSmallBufferSize(conf)))
    );

    success = true;
    return result;
  } finally {
    if (!success) {
      IOUtils.closeSocket(sock);
    }
  }
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:42,代碼來源:NuCypherExtUtilClient.java

示例2: discardStream

import java.net.Socket; //導入方法依賴的package包/類
/**
 * Discards the response body so that the connection can be reused. This
 * needs to be done judiciously, since it delays the current request in
 * order to speed up a potential future request that may never occur.
 *
 * <p>A stream may be discarded to encourage response caching (a response
 * cannot be cached unless it is consumed completely) or to enable connection
 * reuse.
 */
private static boolean discardStream(HttpEngine httpEngine, InputStream responseBodyIn) {
  Connection connection = httpEngine.connection;
  if (connection == null) return false;
  Socket socket = connection.getSocket();
  if (socket == null) return false;
  try {
    int socketTimeout = socket.getSoTimeout();
    socket.setSoTimeout(DISCARD_STREAM_TIMEOUT_MILLIS);
    try {
      Util.skipAll(responseBodyIn);
      return true;
    } finally {
      socket.setSoTimeout(socketTimeout);
    }
  } catch (IOException e) {
    return false;
  }
}
 
開發者ID:aabognah,項目名稱:LoRaWAN-Smart-Parking,代碼行數:28,代碼來源:HttpTransport.java

示例3: DefaultConnection

import java.net.Socket; //導入方法依賴的package包/類
/**
 * 創建與服務端連接
 * 
 * @param address
 * @param soTimeout
 * @param connectTimeout
 */
public DefaultConnection(InetSocketAddress address, int soTimeout, int connectTimeout, Charset charset) {
    try {
        socket = new Socket();
        socket.setSoTimeout(soTimeout);
        LOGGER.debug("connect to {} soTimeout={} connectTimeout={}", address, soTimeout, connectTimeout);
        this.charset = charset;
        socket.connect(address, connectTimeout);
    } catch (IOException e) {
        throw new FdfsConnectException("can't create connection to" + address, e);
    }
}
 
開發者ID:whatodo,項目名稱:FastDFS_Client,代碼行數:19,代碼來源:DefaultConnection.java

示例4: run

import java.net.Socket; //導入方法依賴的package包/類
@Override
public void run() {

    int trials = 0;
    while(trials < Config.MESSAGE_MAX_TRIALS) {

        try {
            log.debug(p.getPeerServerPort());
            log.debug(p.getAddress());
            Socket messagedClient = new Socket(p.getAddress(), p.getPeerServerPort());
            messagedClient.setSoTimeout(Config.MESSAGE_TIMEOUT);
            ObjectOutputStream out = new ObjectOutputStream(messagedClient.getOutputStream());
            out.writeInt(Config.MESSAGE_OUTGOING);
            out.writeUTF(msg);
            out.flush();

            ObjectInputStream in = new ObjectInputStream(new DataInputStream(messagedClient.getInputStream()));
            int ack = in.readInt();
            messagedClient.close();
            if (ack == Config.MESSAGE_ACK) {
                return;
            }

        } catch (IOException e) {

        }
        trials++;
    }
    log.warn("Message cannot be sent after " + Config.MESSAGE_MAX_TRIALS + " trials");
    log.warn(msg);
}
 
開發者ID:CrypDist,項目名稱:CrypDist,代碼行數:32,代碼來源:MessageTask.java

示例5: run

import java.net.Socket; //導入方法依賴的package包/類
/**
 *
 */
public void run() {
    while(true) {
        try {
            Socket connectionSocket = socket.accept();
            connectionSocket.setSoTimeout(60 * 1000); //Close after 1min to avoid socket leakage
            new ManagerThread(connectionSocket, processController).start();
        } catch(Exception e) {
            log.error("Generic error in server with message: "+e.getMessage());
        }
    }
}
 
開發者ID:mware-solutions,項目名稱:sether,代碼行數:15,代碼來源:ManagerRunnable.java

示例6: initialization

import java.net.Socket; //導入方法依賴的package包/類
public void initialization() {

        //Establish a connection with server, get number of active peers and their information.
        try {
            Thread t2 = new ReceiveServerRequest(this);
            t2.start();

            Socket serverConnection = new Socket(swAdr, swPort);
            serverConnection.setSoTimeout(Config.SERVER_TIMEOUT);

            DataInputStream in = new DataInputStream(serverConnection.getInputStream());

            receivePeerList(in);

            //Send itself data to server.
            DataOutputStream out = new DataOutputStream(serverConnection.getOutputStream());
            out.writeInt(heartBeatPort);
            out.writeInt(serverPort);
            out.writeUTF(Config.USER_NAME);
            out.writeUTF(Config.USER_PASS);
            out.flush();

            boolean authenticated = in.readBoolean();
            active = in.readBoolean();
            crypDist.setActive(active);
            int size = in.readInt();
            byte[] key_array = new byte[size];
            in.read(key_array);

            crypDist.setSessionKey(key_array);
            crypDist.setAuthenticated(authenticated);

            serverConnection.close();
        }
        catch(IOException e)
        {
            log.warn("Cannot connect to the server, terminated.");
            log.warn(e);
        }
    }
 
開發者ID:CrypDist,項目名稱:CrypDist,代碼行數:41,代碼來源:Client.java

示例7: getSocket

import java.net.Socket; //導入方法依賴的package包/類
/**
 * construct Socket object
 * @param ip_addr ip address or hostname
 * @param port port number
 * @return connected Socket object
 */
public static Socket getSocket(String ip_addr, int port) throws IOException {
    Socket sock = new Socket();
    sock.setSoTimeout(ClientGlobal.g_network_timeout);
    sock.connect(new InetSocketAddress(ip_addr, port), ClientGlobal.g_connect_timeout);
    return sock;
}
 
開發者ID:babymm,項目名稱:mumu,代碼行數:13,代碼來源:ClientGlobal.java

示例8: handshake

import java.net.Socket; //導入方法依賴的package包/類
/**
 * Handshake with the debuggee
 */
void handshake(Socket s, long timeout) throws IOException {
    s.setSoTimeout((int)timeout);

    byte[] hello = "JDWP-Handshake".getBytes("UTF-8");
    s.getOutputStream().write(hello);

    byte[] b = new byte[hello.length];
    int received = 0;
    while (received < hello.length) {
        int n;
        try {
            n = s.getInputStream().read(b, received, hello.length-received);
        } catch (SocketTimeoutException x) {
            throw new IOException("handshake timeout");
        }
        if (n < 0) {
            s.close();
            throw new IOException("handshake failed - connection prematurally closed");
        }
        received += n;
    }
    for (int i=0; i<hello.length; i++) {
        if (b[i] != hello[i]) {
            throw new IOException("handshake failed - unrecognized message from target VM");
        }
    }

    // disable read timeout
    s.setSoTimeout(0);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:34,代碼來源:SocketTransportService.java

示例9: ping

import java.net.Socket; //導入方法依賴的package包/類
public static PingResult ping(com.badlogic.gdx.net.Socket gdxSocket) throws Exception {
  Socket javaSocket = extractJavaSocket(gdxSocket);
  DataOutputStream dataOutputStream = new DataOutputStream(javaSocket.getOutputStream());
  Long firstTime = System.currentTimeMillis();
  dataOutputStream.writeByte(1); //1 is ping
  javaSocket.setSoTimeout(TIMEOUT);
  try {
    DataInputStream dataInputStream = new DataInputStream(javaSocket.getInputStream());
    PingResult pingResult = new PingResult();
    pingResult.serverMajor = dataInputStream.readInt();
    Long secondTime = System.currentTimeMillis();
    pingResult.serverMinor = dataInputStream.readInt();
    pingResult.serverPoint = dataInputStream.readInt();
    pingResult.serverBuild = dataInputStream.readInt();
    pingResult.serverHash = dataInputStream.readUTF();
    int playerNum = dataInputStream.readInt();
    pingResult.players = new String[playerNum];
    for (int i = 0; i < pingResult.players.length; i++) {
      pingResult.players[i] = dataInputStream.readUTF();
    }
    pingResult.ping = (int) (secondTime - firstTime);
    gdxSocket.dispose();
    return pingResult;
  } catch (IOException e) {
    if (e instanceof SocketTimeoutException) {
      throw new IOException("Server did not respond in time", e);
    } else {
      throw e;
    }
  }
}
 
開發者ID:RedTroop,項目名稱:Cubes,代碼行數:32,代碼來源:ClientConnectionInitializer.java

示例10: initSocket

import java.net.Socket; //導入方法依賴的package包/類
private static Socket initSocket(Config config, InetSocketAddress address) throws IOException {
    Socket socket = new Socket();
    socket.setSoTimeout(config.mTransportTimeOut);
    socket.connect(address, config.mConnectTimeOut);
    socket.setKeepAlive(true);
    return socket;
}
 
開發者ID:android-notes,項目名稱:vase,代碼行數:8,代碼來源:HttpUtils.java

示例11: fillInputBuffer

import java.net.Socket; //導入方法依賴的package包/類
private int fillInputBuffer(final int timeout) throws IOException {
    final Socket socket = this.socketHolder.get();
    final int oldtimeout = socket.getSoTimeout();
    try {
        socket.setSoTimeout(timeout);
        return this.inbuffer.fillBuffer();
    } finally {
        socket.setSoTimeout(oldtimeout);
    }
}
 
開發者ID:kalikov,項目名稱:lighthouse,代碼行數:11,代碼來源:BHttpConnectionBase.java

示例12: createConnection

import java.net.Socket; //導入方法依賴的package包/類
@Override
public DuplexTransportConnection createConnection(ContactId c) {
	if (!isRunning()) return null;
	TransportProperties p = callback.getRemoteProperties().get(c);
	if (p == null) return null;
	String onion = p.get(PROP_ONION);
	if (StringUtils.isNullOrEmpty(onion)) return null;
	if (!ONION.matcher(onion).matches()) {
		// not scrubbing this address, so we are able to find the problem
		if (LOG.isLoggable(INFO)) LOG.info("Invalid hostname: " + onion);
		return null;
	}
	Socket s = null;
	try {
		if (LOG.isLoggable(INFO))
			LOG.info("Connecting to " + scrubOnion(onion));
		controlConnection.forgetHiddenService(onion);
		s = torSocketFactory.createSocket(onion + ".onion", 80);
		s.setSoTimeout(socketTimeout);
		if (LOG.isLoggable(INFO))
			LOG.info("Connected to " + scrubOnion(onion));
		return new TorTransportConnection(this, s);
	} catch (IOException e) {
		if (LOG.isLoggable(INFO)) {
			LOG.info("Could not connect to " + scrubOnion(onion) + ": " +
					e.toString());
		}
		tryToClose(s);
		return null;
	}
}
 
開發者ID:rafjordao,項目名稱:Nird2,代碼行數:32,代碼來源:TorPlugin.java

示例13: openTcpConnect

import java.net.Socket; //導入方法依賴的package包/類
private void openTcpConnect(int timeout) throws S7Exception {
    try {
        tcpSocket = new Socket();
        tcpSocket.connect(new InetSocketAddress(config.getHost(), config.getPort()), timeout);
        tcpSocket.setTcpNoDelay(true);
        tcpSocket.setSoTimeout(recvTimeout);
        inStream = new BufferedInputStream(tcpSocket.getInputStream());
        outStream = new BufferedOutputStream(tcpSocket.getOutputStream());
    } catch (IOException e) {
        throw buildException(TCP_CONNECTION_FAILED, e);
    }
}
 
開發者ID:comtel2000,項目名稱:mokka7,代碼行數:13,代碼來源:S7Client.java

示例14: connect

import java.net.Socket; //導入方法依賴的package包/類
/**
* connect to server
* @return connected Socket object
*/
	public Socket connect() throws IOException
	{
		Socket sock = new Socket();
		sock.setReuseAddress(true);
		sock.setSoTimeout(ClientGlobal.g_network_timeout);
		sock.connect(new InetSocketAddress(this.ip_addr, this.port), ClientGlobal.g_connect_timeout);
		return sock;
	}
 
開發者ID:tb544731152,項目名稱:iBase4J,代碼行數:13,代碼來源:ServerInfo.java

示例15: initSocket

import java.net.Socket; //導入方法依賴的package包/類
private void initSocket()throws Exception{
	socket = new Socket(this.host, this.port);
	socket.setSoTimeout(timeout);
	in = socket.getInputStream();
	out = socket.getOutputStream();
}
 
開發者ID:ahhblss,項目名稱:ddpush,代碼行數:7,代碼來源:Pusher.java


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