次の問題があります:Hackageからページを取得すると、大きな遅延(約30秒)が発生します。それ以降のリクエストは高速ですが、数分間接続しないと、問題が再発します。
この問題の興味深い点は次のとおりです。
- それはこの特定のサイトに固有のものです(ハック)—他のサイトでも同様の問題は発生しません(そして、私はかなりの数を訪れます)。
- 私のISPに固有のようです。他の場所から接続する場合、そのような問題はありません。
DNSや接続の問題とは関係ありません。実際、TCP接続はすぐに確立されます。次のサンプルパケットキャプチャからわかるように、時間がかかりすぎるのはHTTP応答です。
1 0.000000000 192.168.1.101 -> 66.193.37.204 TCP 66 41518 > http [SYN] Seq=0 Win=13600 Len=0 MSS=1360 SACK_PERM=1 WS=16 2 0.205708000 66.193.37.204 -> 192.168.1.101 TCP 66 http > 41518 [SYN, ACK] Seq=0 Ack=1 Win=5840 Len=0 MSS=1440 SACK_PERM=1 WS=128 3 0.205759000 192.168.1.101 -> 66.193.37.204 TCP 54 41518 > http [ACK] Seq=1 Ack=1 Win=13600 Len=0 4 0.205846000 192.168.1.101 -> 66.193.37.204 HTTP 158 GET /packages/hackage.html HTTP/1.1 5 0.406461000 66.193.37.204 -> 192.168.1.101 TCP 54 http > 41518 [ACK] Seq=1 Ack=105 Win=5888 Len=0 6 28.433860000 66.193.37.204 -> 192.168.1.101 TCP 1494 [TCP segment of a reassembled PDU] 7 28.433904000 192.168.1.101 -> 66.193.37.204 TCP 54 41518 > http [ACK] Seq=105 Ack=1441 Win=16480 Len=0 8 28.434211000 66.193.37.204 -> 192.168.1.101 HTTP 1404 HTTP/1.1 200 OK (text/html) 9 28.434228000 192.168.1.101 -> 66.193.37.204 TCP 54 41518 > http [ACK] Seq=105 Ack=2791 Win=19360 Len=0 10 28.434437000 192.168.1.101 -> 66.193.37.204 TCP 54 41518 > http [FIN, ACK] Seq=105 Ack=2791 Win=19360 Len=0 11 28.635146000 66.193.37.204 -> 192.168.1.101 TCP 54 http > 41518 [FIN, ACK] Seq=2791 Ack=106 Win=5888 Len=0 12 28.635191000 192.168.1.101 -> 66.193.37.204 TCP 54 41518 > http [ACK] Seq=106 Ack=2792 Win=19360 Len=0
(pcap-ng形式のパケットキャプチャ)。このキャプチャは、単純なの間に何が起こるかを示してい
curl http://hackage.haskell.org/packages/hackage.html
ます。
また、ルーターの背後にいることも関係ありません。直接接続する場合も同じです。接続タイプはPPPoEです。
LinuxとWindowsを実行する3台のコンピューターで問題を再現しました。
このような問題を診断する方法は?