On Tue, 16 May 2006 10:50:30 +0200
"Radko Mihal" <[EMAIL PROTECTED]> wrote:

> Hi,
> 
> We are facing strange problem with disabling the Nagle's algorithm via 
> setting the TCP_NODELAY flag on server socket (setsockopt), where server is 
> communication with client via loopback.
> After the first segment (of the response) is sent by server side, server is 
> waiting for ACK instead of continuing sending next segments (as it should use 
> sliding window principle). The client sends ACK after 40 ms, only then server 
> sends the rest of responses packed into one segment. The 40 ms is a big delay 
> and causes reponse processing to be 10 times slower.
> 
> The thing doesn't happen, if we move client to another host. In that case the 
> server don't wait for ACK, don't pack responses and also response processing 
> is much faster.
> 
> It seems, like on loopback the Nagle's alg. is still acting (citate from alg. 
> description says:"a first segment is sent immediately, while further data on 
> the sender side is buffered until either a full maximum segment can be sent 
> or an acknowledgement for the first segment is received)
> 
> I found some descriptions of the same problem, but with no solution!
> Is there a bug in setsockopt()? We are using 2.6.5 kernel.

If it is 2.6.5 that is over 2+ years old. Please try with something past the 
Pleistocene era...

More likely, you mean 2.6.15 and you are seeing the effect of TCP ABC.  ABC is 
appropriate byte count
and it penalizes applications that do small sends. The correct fix is to change 
your application
to use TCP_CORK or do consolidation with writev(), sendmsg(), etc. This came up 
with the Java
debugger, see mailing list archives.
-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to