[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <4630D58E.5020709@hp.com>
Date: Thu, 26 Apr 2007 09:38:38 -0700
From: Rick Jones <rick.jones2@...com>
To: Ilpo Järvinen <ilpo.jarvinen@...sinki.fi>
Cc: Netdev <netdev@...r.kernel.org>
Subject: Re: Unexcepted latency (order of 100-200 ms) with TCP (packet receive)
Ilpo Järvinen wrote:
> Hi,
>
> ...
> Some time ago I noticed that with 2.6.18 I occassionally get latency
> spikes as long as 100-200ms in the TCP transfers between components
> (I describe later how TCP was tuned during these tests to avoid
> problems that occur with small segments). I started to investigate
> the spikes, and here are the findings so far:
> ...
> - I placed a hub to get exact timings on the wire without potential
> interference from tcpdump on the emulator host (test done with 2.6.18)
> but to my great surprise, the problem vanished completely
Sounds like tcpdump getting in the way? How many CPUs do you have in
the system, and have you tried some explicit binding of processes to
different CPUs? (taskset etc...)
When running tcpdump are you simply sending raw traces to a file, or are
you having the ASCII redirected to a file? What about name resolution
(ie areyou using -n)?
> - Due to the hub test result, I tested 10/100/duplex settings and found
> out that if the emulator host has 10fd, the problem does not occur with
> 2.6 either?!? This could be due to luck but I cannot say for sure, yet
> the couple of tests I've run with 10fd, did not show this...
> - Tried to change cable & switch that connect hosts together, no effect
>
>
> To prove this with 100Mbps, I setup routing so that with a host with 10/FD
> configuration (known, based on earlier, to be unlikely to cause errors) I
> collected all traffic between the emulator host and one of the packet
> capture hosts. Here is one example point where a long delay occurs
> (EMU is the emulator host, in the real log each packet is shown twice, I
> only leave the later one here):
>
> 1177577267.364596 IP CAP.35305 > EMU.52246: . 17231434:17232894(1460) ack 383357 win 16293
> 1177577267.364688 IP CAP.35305 > EMU.52246: P 17232894:17232946(52) ack 383357 win 16293
> 1177577267.366093 IP EMU.52246 > CAP.35305: . ack 17232894 win 32718
> 1177577267.493815 IP EMU.52246 > CAP.35305: P 383357:383379(22) ack 17232894 win 32718
> 1177577267.534252 IP CAP.35305 > EMU.52246: . ack 383379 win 16293
What is the length of the standalone ACK timer these days?
> 1177577267.534517 IP EMU.59050 > CAP.58452: P 624496:624528(32) ack 328 win 365
> 1177577267.534730 IP CAP.58452 > EMU.59050: . ack 624528 win 16293
> 1177577267.536267 IP CAP.35305 > EMU.52246: . 17232946:17234406(1460) ack 383379 win 16293
> 1177577267.536360 IP CAP.35305 > EMU.52246: P 17234406:17234458(52) ack 383379 win 16293
> 1177577267.537764 IP EMU.52246 > CAP.35305: . ack 17234406 win 32718
> ...
> All things use TCP_NODELAY. The network is isolated so that
> no other traffic can cause unexcepted effects. The emulator does collect
> log only to a mem buffer that is flushed through TCP only between tests
> (and thus does not cause timing problems).
Might tcp_abc have crept back-in?
rick jones
-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists