[英]Connection timeout occurs while connecting through telnet
我正在使用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)
提前致謝..
任何方式都不能使TCP連接超時超過平台默認值(大約一分鍾)。 您只能減少它。 與Javadoc在幾個地方所說的相反,零連接超時並不意味着無窮大,這意味着平台是默認的。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.