通过telnet连接时发生连接超时

时间:2015-02-03 06:58:48

标签: java serversocket connection-timeout apache-commons-net

我正在使用apache-commons-net.2.0.jar编写一个telnetclient示例,以使用telnet协议连接到目标。 如果主机启动并运行,则它与主机建立连接的jar没有问题。如果我重新启动系统并尝试连接到主机telnetclient正在抛出连接超时异常。

telnetClient.setConnectionTimoeout(180 * 1000) - >设置180秒连接超时 telnetClient.setDefaultTimoeout(180 * 1000)

Telnet客户端不会等待180秒。它会在30秒(大约)后抛出连接超时异常。 我尝试使用commons-net-3.0.jar并获得相同的异常。 根据我的理解,如果主机未启动,setConnectionTimeout应该等待180秒。

  import java.io.IOException;
import org.apache.commons.net.telnet.TelnetClient;
import java.net.*;

class TelnetClientExample
{
    public static void main(String[] args)
    {
    System.out.println("Started");
        TelnetClient telnet;
        telnet = new TelnetClient();
        try
        {
            telnet.setConnectTimeout(1800000);
        telnet.setDefaultTimeout(1800000);
        telnet.connect(InetAddress.getByName("hostname"),23);
            //telnet.connect("ipaddress", 23);
        System.out.println("Connected");

        }
        catch (IOException e)
        {
            e.printStackTrace();
        System.out.println("Connection timeout = "+telnet.getConnectTimeout());
            System.exit(1);
        }
    try
        {
            telnet.disconnect();
        }
        catch (IOException e)
        {
            e.printStackTrace();
            System.exit(1);
        }
        System.exit(0);
    }
}

错误:

Started
java.net.ConnectException: Connection timed out
    at java.net.PlainSocketImpl.socketConnect(Native Method)
    at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:339)
    at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:200)
    at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:182)
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:391)
    at java.net.Socket.connect(Socket.java:579)
    at org.apache.commons.net.SocketClient.connect(SocketClient.java:182)
    at TelnetClientExample.main(TelnetClientExample.java:17)

先谢谢..

1 个答案:

答案 0 :(得分:1)

您无法通过任何方式将TCP连接超时增加到平台默认值(大约一分钟)之外。你只能减少它。与Javadoc在几个地方所说的相反,零连接超时并不意味着无穷大,这意味着平台默认。