[e2e] tcp connection timeout
Joe Touch
touch at ISI.EDU
Fri Mar 3 07:54:13 PST 2006
Vadim Antonov wrote:
...
>> If there are no costs for listening, I see no problem here.
>
> There always costs. They may be small (like keeping a TCB), they may be
> large (like keeping 20Mb of state in RAM), they may be intolerable - but
> there are always some, and you do not have any idea of the costs imposed
> on the remote end.
Please explain the 20MB case.
AFAICT, that only happens when the receiver window is 20MB, AND:
a) the received data has a hole in it, notably at least
at the beginning, and 20MB of other stuff backed up waiting
for retransmission
in that case, TCP *WILL* timeout due to a number
of failed ACK retransmissions
b) the received data does NOT have a hole in it,
but the application has not yet retrieved the data
in this case, if TCP were to 'timeout',
the application would be interrupted
unnecessarily
Based on the above, *IF* you have 20MB associated with a connection, TCP
should not be timing-out on that connection.
I.e., the only case where it *might* be appropriate to timeout due to
idleness is the case where the receive buffer is empty. It seems
feasible to have TCP release those buffers in that case, at which point
the only space an idle TCP connection should hold is the TCB, which
isn't that large.
If a system cannot hold a large number of TCBs, then the application
should be cleaning them up themselves. Or a background OS process can go
around doing this. But this isn't TCP's job.
Joe
More information about the end2end-interest
mailing list