Socket connect timeouts: where is the specification?

前端 未结 2 1447
鱼传尺愫
鱼传尺愫 2021-02-10 08:15

The context of my work is my local area network.

The code samples below are written in Java language but my question is about TCP, not programming.

I have experi

2条回答
  •  情深已故
    2021-02-10 08:57

    There is no RFC for connection timeouts. It is impossible for any RFC or other document to know the conditions prevailing in any network in advance.

    In general you can expect a successful connection to be very quick; an ECONNREFUSED (ConnectException: connection refused) to be about as quick; and a connection timeout (ConnectException: connect timeout) to take as long as it takes, depending on the cause, the platforms at both ends, and the nature of the intervening network. In Windows I believe a connection timeout consists of the total time across three connection attempts with timeouts 6s, 12s, and 24s, total 42s; in various Unixes I believe the total is more like 70s, which could result from 3 attempts with timeouts 10s, 20s, and 40s. As you see it is up to the platform. There is also the issue that filling the backlog queue at a Windows server will cause RSTs to be issued to incoming SYNs, where on a Unix/Linux server it will cause no response at all to incoming SYNs.

    You should also note that in Java, and contrary to many years of Javadoc:

    1. A zero connect timeout does not imply an infinite timeout, it implies the platform default timeout, which as shown above isn't above about 70s;

    2. You cannot specify a connection timeout that increases the platform default; you can only use it to decrease the platform default.

提交回复
热议问题