【问题标题】:Connection timeout occurs while connecting through telnet通过 telnet 连接时发生连接超时
【发布时间】:2015-02-03 15:08:37
【问题描述】:

我正在编写一个使用 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)

提前致谢..

【问题讨论】:

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


    【解决方案1】:

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

    【讨论】:

    • 感谢@EJP 我给了 59 秒,但没有用。仍然连接超时。我正在重新启动一个不超过 30 秒的虚拟机..
    • 我在 /etc/sysctl.conf 中增加了超时但没有用。仍然发生超时。有什么方法可以增加超时时间,以便我可以在超时后连接到主机
    • 如果你得到一个合理的超时时间的连接超时,这是一个网络连接问题,或者防火墙只是丢弃了连接请求。
    • 更改 tcp timeout 的默认值后,它工作正常。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-09-29
    • 1970-01-01
    • 2010-12-22
    • 2012-06-15
    • 2022-01-14
    • 1970-01-01
    • 2010-11-10
    相关资源
    最近更新 更多