Тайм-аут подключения происходит при подключении через telnet

Я пишу пример telnetclient, используя apache-commons-net.2.0.jar для подключения к цели с использованием протокола telnet. С банкой проблем нет, она устанавливает соединение с хостом, если хост запущен и работает. Если я перезагружаю систему и пытаюсь подключиться к хосту, 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)

Заранее спасибо..


person Shriram    schedule 03.02.2015    source источник


Ответы (1)


Вы не можете каким-либо образом увеличить время ожидания TCP-соединения сверх значения по умолчанию для платформы (около минуты). Можно только уменьшить. Вопреки тому, что говорится в Javadoc в нескольких местах, нулевой тайм-аут соединения не означает бесконечность, это означает платформу по умолчанию.

person user207421    schedule 03.02.2015
comment
спасибо @EJP Я дал 59 секунд и бесполезно. все еще тайм-аут соединения. Я перезагружаю виртуальную машину, которая занимает не более 30 секунд. - person Shriram; 03.02.2015
comment
Я увеличил время ожидания в /etc/sysctl.conf, но бесполезно. Тем не менее тайм-аут происходит. Есть ли способ увеличить тайм-аут, чтобы я мог подключиться к хосту после тайм-аута? - person Shriram; 03.02.2015
comment
Если вы получили тайм-аут подключения с разумным периодом ожидания, это проблема с сетевым подключением или брандмауэр просто отбрасывает запрос на подключение. - person user207421; 03.02.2015
comment
После изменения значений тайм-аута tcp по умолчанию все работает нормально. - person Shriram; 03.02.2015