Tillbaka till svenska Fidonet
English   Information   Debug  
HUMOR   0/29
IC   0/2851
INTERNET   0/424
INTERUSER   0/3
IP_CONNECT   719
JAMNNTPD   0/233
JAMTLAND   0/47
KATTY_KORNER   0/41
LAN   0/16
LINUX-USER   0/19
LINUXHELP   0/1155
LINUX   0/22112
LINUX_BBS   0/957
mail   18.68
mail_fore_ok   249
MENSA   0/341
MODERATOR   0/102
MONTE   0/992
MOSCOW_OKLAHOMA   0/1245
MUFFIN   0/783
MUSIC   0/321
N203_STAT   930
N203_SYSCHAT   313
NET203   321
NET204   69
NET_DEV   0/10
NORD.ADMIN   0/101
NORD.CHAT   0/2572
NORD.FIDONET   189
NORD.HARDWARE   0/28
NORD.KULTUR   0/114
NORD.PROG   0/32
NORD.SOFTWARE   0/88
NORD.TEKNIK   0/58
NORD   0/453
OCCULT_CHAT   0/93
OS2BBS   0/787
OS2DOSBBS   0/580
OS2HW   0/42
OS2INET   0/37
OS2LAN   0/134
OS2PROG   0/36
OS2REXX   0/113
OS2USER-L   207
OS2   0/4786
OSDEBATE   0/18996
PASCAL   0/490
PERL   0/457
PHP   0/45
POINTS   0/405
POLITICS   0/29554
POL_INC   0/14731
PSION   103
R20_ADMIN   1123
R20_AMATORRADIO   0/2
R20_BEST_OF_FIDONET   13
R20_CHAT   0/893
R20_DEPP   0/3
R20_DEV   399
R20_ECHO2   1379
R20_ECHOPRES   0/35
R20_ESTAT   0/719
R20_FIDONETPROG...
...RAM.MYPOINT
  0/2
R20_FIDONETPROGRAM   0/22
R20_FIDONET   0/248
R20_FILEFIND   0/24
R20_FILEFOUND   0/22
R20_HIFI   0/3
R20_INFO2   3249
R20_INTERNET   0/12940
R20_INTRESSE   0/60
R20_INTR_KOM   0/99
R20_KANDIDAT.CHAT   42
R20_KANDIDAT   28
R20_KOM_DEV   112
R20_KONTROLL   0/13300
R20_KORSET   0/18
R20_LOKALTRAFIK   0/24
R20_MODERATOR   0/1852
R20_NC   76
R20_NET200   245
R20_NETWORK.OTH...
...ERNETS
  0/13
R20_OPERATIVSYS...
...TEM.LINUX
  0/44
R20_PROGRAMVAROR   0/1
R20_REC2NEC   534
R20_SFOSM   0/341
R20_SF   0/108
R20_SPRAK.ENGLISH   0/1
R20_SQUISH   107
R20_TEST   2
R20_WORST_OF_FIDONET   12
RAR   0/9
RA_MULTI   106
RA_UTIL   0/162
REGCON.EUR   0/2056
REGCON   0/13
SCIENCE   0/1206
SF   0/239
SHAREWARE_SUPPORT   0/5146
SHAREWRE   0/14
SIMPSONS   0/169
STATS_OLD1   0/2539.065
STATS_OLD2   0/2530
STATS_OLD3   0/2395.095
STATS_OLD4   0/1692.25
SURVIVOR   0/495
SYSOPS_CORNER   0/3
SYSOP   0/84
TAGLINES   0/112
TEAMOS2   0/4530
TECH   0/2617
TEST.444   0/105
TRAPDOOR   0/19
TREK   0/755
TUB   0/290
UFO   0/40
UNIX   0/1316
USA_EURLINK   0/102
USR_MODEMS   0/1
VATICAN   0/2740
VIETNAM_VETS   0/14
VIRUS   0/378
VIRUS_INFO   0/201
VISUAL_BASIC   0/473
WHITEHOUSE   0/5187
WIN2000   0/101
WIN32   0/30
WIN95   0/4289
WIN95_OLD1   0/70272
WINDOWS   0/1517
WWB_SYSOP   0/419
WWB_TECH   0/810
ZCC-PUBLIC   0/1
ZEC   4

 
4DOS   0/134
ABORTION   0/7
ALASKA_CHAT   0/506
ALLFIX_FILE   0/1313
ALLFIX_FILE_OLD1   0/7997
ALT_DOS   0/152
AMATEUR_RADIO   0/1039
AMIGASALE   0/14
AMIGA   0/331
AMIGA_INT   0/1
AMIGA_PROG   0/20
AMIGA_SYSOP   0/26
ANIME   0/15
ARGUS   0/924
ASCII_ART   0/340
ASIAN_LINK   0/651
ASTRONOMY   0/417
AUDIO   0/92
AUTOMOBILE_RACING   0/105
BABYLON5   0/17862
BAG   135
BATPOWER   0/361
BBBS.ENGLISH   0/382
BBSLAW   0/109
BBS_ADS   0/5290
BBS_INTERNET   0/507
BIBLE   0/3563
BINKD   0/1119
BINKLEY   0/215
BLUEWAVE   0/2173
CABLE_MODEMS   0/25
CBM   0/46
CDRECORD   0/66
CDROM   0/20
CLASSIC_COMPUTER   0/378
COMICS   0/15
CONSPRCY   0/899
COOKING   33421
COOKING_OLD1   0/24719
COOKING_OLD2   0/40862
COOKING_OLD3   0/37489
COOKING_OLD4   0/35496
COOKING_OLD5   9370
C_ECHO   0/189
C_PLUSPLUS   0/31
DIRTY_DOZEN   0/201
DOORGAMES   0/2065
DOS_INTERNET   0/196
duplikat   6002
ECHOLIST   0/18295
EC_SUPPORT   0/318
ELECTRONICS   0/359
ELEKTRONIK.GER   1534
ENET.LINGUISTIC   0/13
ENET.POLITICS   0/4
ENET.SOFT   0/11701
ENET.SYSOP   33945
ENET.TALKS   0/32
ENGLISH_TUTOR   0/2000
EVOLUTION   0/1335
FDECHO   0/217
FDN_ANNOUNCE   0/7068
FIDONEWS   24159
FIDONEWS_OLD1   0/49742
FIDONEWS_OLD2   0/35949
FIDONEWS_OLD3   0/30874
FIDONEWS_OLD4   0/37224
FIDO_SYSOP   12852
FIDO_UTIL   0/180
FILEFIND   0/209
FILEGATE   0/212
FILM   0/18
FNEWS_PUBLISH   4436
FN_SYSOP   41706
FN_SYSOP_OLD1   71952
FTP_FIDO   0/2
FTSC_PUBLIC   0/13613
FUNNY   0/4886
GENEALOGY.EUR   0/71
GET_INFO   105
GOLDED   0/408
HAM   0/16074
HOLYSMOKE   0/6791
HOT_SITES   0/1
HTMLEDIT   0/71
HUB203   466
HUB_100   264
HUB_400   39
Möte LINUXHELP, 1155 texter
 lista första sista föregående nästa
Text 862, 144 rader
Skriven 2006-07-28 21:23:42 av John Beckett (1:379/45)
    Kommentar till text 858 av Mike N. (1:379/45)
Ärende: Re: Window Scale handling on Windows 2000
=================================================
From: John Beckett <FirstnameSurname@compuserve.com.omit>

Mike - I've now studied the network capture you sent. I can't work out the
cause of the problem, but here are my thoughts. I had to review a lot of TCP
stuff, and am including my notes here for anyone interested.

Skip down to "Conclusion" (namely that I don't know) if you want to miss the
waffle.

---Scenario---

Client (Linux) opens a TCP connection to server (news.barkto.com).

Client sends SYN to open the connection, with TCP options:
  MSS = 1460 bytes (maximum segment size)
  SACK permitted (selective acknowledgments)
  Timestamp: tsval, tsecr
  Window scale = 7 (multiply Window field by 128)

Server replies with its own SYN and TCP options:
  MSS = 1460 bytes
  SACK permitted
  Timestamp: tsval, tsecr
  Window scale = 0 (multiply Window by 1 - no scaling)

---Theory---

RFC 1323 "TCP Extensions for High Performance" explains concepts.

One aim is to allow the receiver to have a large receive buffer, and to
advertise a large receive window, so the sender can send lots of data without
having to wait for acknowledgments (ACK).

The MSS option means each side will never send more than 1460 bytes in one IP
datagram. Not relevant to barkto problem.

SACK allows a receiver to ACK data it has received, while indicating that some
data was missed. That allows the sender to re-send only the missing data
(without SACK, all data since the missed bytes needs to be re-sent). SACK is
not relevant to the barkto problem (in Mike's short capture illustrating the
problem, there are no missing or re-sent bytes).

The client says it supports "window scale = 7" and the server says it supports
windows scaling, and has "window scale = 0". That means, for example, that if a
TCP packet from the client includes "window = 100", then the client has a
receive window of 100 * 2^7 = 12800 bytes. That is, the server can send up to
12800 bytes to the client without having to wait for an ACK.

However if the server sends a TCP packet with "window = 100", then the server
has a receive window of 100 bytes.

The timestamp stuff is to allow each side to estimate the round trip time. For
example, if RTT = 100 ms, then the sender should expect that an ACK would not
be delayed more than 100 ms. If no ACK comes within a reasonable amount of
time, then the sender should assume the data was lost and re-send.

tsval = timestamp value (number of ticks) at sender tsecr = timestamp echo
reply (tsval last received from other side)

The "ticks" can be (almost) any convenient measure of time - it has meaning
only to the computer that sends tsval. If computer A sends tsval = 100 to
computer B, then B (in its next reply) should include B's tsval and tsecr =
100. Computer A knows when the reply arrived, and sees that it was sent at
ticks = 100, so can calculate the RTT.

---Problem---

Mike's capture shows that the client requests a certain article. The server
then proceeds to send the article. There are a couple of places where the
server sends an unexpectedly small amount of data in a single packet. Perhaps
that was just bad luck, or DNews is a bit stupid, or maybe Geo has somehow
disabled the Nagle algorithm. At any rate, it's not a big deal.

But then, the server sends an article that is 1047 bytes. Instead of sending it
in one packet, the server goes crazy. It sends:
  1 packet of 512 bytes
  65 packets of 1 byte each (i.e. 1 byte of data in each)
  1 packet of 470 bytes

There is an average 0.3 second delay between each packet that the server sends.
Result: one article (1047 bytes) takes 20 seconds to download (plus a 5 second
delay before the article actually starts to be sent).

---Analysis---

I can't see any reason for the server to start sending one-byte packets. The
client correctly advertises that it can receive a large window (11,136 bytes),
and the client very promptly acknowledges each segment it received. All the TCP
header values appear to be OK.

The only reason I know for a sender to start sending one-byte packets is
something called a "zero window probe". The intended scenario is where the
sender has sent a bunch of data that has filled the receive buffer of the
receiver. Therefore the receiver sends an ACK with Window = 0 (indicating that
nothing more can be received at the moment).

The sender then waits, hoping that the receiver will send another ACK with
Window > 0, so sending can be resumed. However, in case such an ACK is lost,
the sender will periodically do a "zero window probe". One form of this is to
send one more byte of data. The timeout is based on an analysis of the observed
RTT.

---Conclusion---

My *guess* is that Geo's Windows server is confused by the window scaling
option used by Mike's Linux client. Somehow, the server thinks that the client
is advertising a zero (or maybe a negative?) receive window size. Therefore the
server patiently waits for an ACK with Window > 0. But it doesn't come, so the
server does a zero window probe after a timeout (approx 0.3 seconds in scenario
observed).

But why can't I locate hundreds of people complaining about this in Google?
There are plenty of posts about slowdowns, and how the registry entry that Mike
mentioned helped them (add DWORD value Tcp1323Opts set to 0 in
HKLM\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters -- that disables
timestamps and window scaling; if window scaling is not supported on one end,
it will not be used by either end).

However, I can't find any explanations. Mike's workaround to disable window
scaling on his client is good, but hardly satisfying.

Also, even if the rogue router that Mike mentioned existed (one which silently
changed the window scaling option to 0 for the server or the client), I don't
see how that would explain the capture.

FYI, here is a mildly interesting page ("invisible") that I found while
stumbling around in Google trying to get info on this.

http://research.microsoft.com/invisible/src/net/tcp/tcp_out.c.htm

---Speculation---

Mike is using a NAT router. I wonder if it is somehow interfering with the TCP
parameters.

It would be very interesting for Mike and Geo to arrange a particular time when
Geo would capture traffic at the server, and Mike would do likewise at the
client. Geo could apply a filter to save just the packets to/from Mike's
system. Then we could compare what is seen at the two computers.

John

--- BBBS/NT v4.01 Flag-5
 * Origin: Barktopia BBS Site http://HarborWebs.com:8081 (1:379/45)