Я являюсь сетевым трафиком и хочу разделить каждый сеанс TCP на серию запросов и ответов (все протоколы, с которыми я работаю, работают так же, как HTTP или SSL).
У меня было простое предположение (игнорирование неупорядоченных и повторно отправленных пакетов) - учитывая кусок данных, которые должны быть отправлены, они будут отправлены с использованием максимально возможных пакетов, а последний пакет будет либо меньше максимального размера, либо будет сопровождаться пакетом с другой стороны (игнорируя пустые пакеты ACK). Так что в сеансе HTTP я ожидаю увидеть что-то вроде (опять же, игнорируя acks) -
Пакет 1 - Запрос "Получить ..."
Пакет 2 - Ответ, размер 1434
Пакет 3 - Ответ, размер 1434
Пакет 4 - Ответ, размер 1434
Пакет 5 - Ответ, размер 500
Это то, что я получаю на большинстве сессий, однако я видел, по крайней мере, один случай, который выглядел как
Пакет 1 - Запрос "Получить ..."
Пакет 2 - Ответ, размер 1434
Пакет 3 - Ответ, размер 1080
Пакет 4 - Ответ, размер 1434
Пакет 5 - Ответ, размер 500
Здесь нет повторных передач, неупорядоченных пакетов или исключительных задержек на сервере.
Я хочу знать - что может вызвать это и когда это произойдет? Насколько неверно мое предположение?
ОБНОВИТЬ
Я положил пример файла pcap здесь
ОБНОВЛЕНИЕ 2
Включая tshark
дамп с соответствующими полями ...
$ tshark -r http_1082.pcap -T fields -e frame.number -e frame.len \
-e ip.src -e ip.dst -e tcp.flags.push -e http.request.method \
-e http.request.uri -e http.response.code | head -n 47
1 66 192.168.1.103 206.33.49.126 0
2 62 206.33.49.126 192.168.1.103 0
3 64 192.168.1.103 206.33.49.126 0
4 411 192.168.1.103 206.33.49.126 1 GET /money/.element/script/3.0/video/xmp/xmp_playlistapi.js
5 54 206.33.49.126 192.168.1.103 0
6 1434 206.33.49.126 192.168.1.103 0
7 1434 206.33.49.126 192.168.1.103 0
8 64 192.168.1.103 206.33.49.126 0
9 1434 206.33.49.126 192.168.1.103 0
10 1434 206.33.49.126 192.168.1.103 0
11 1434 206.33.49.126 192.168.1.103 0
12 64 192.168.1.103 206.33.49.126 0
13 1434 206.33.49.126 192.168.1.103 0
14 1434 206.33.49.126 192.168.1.103 0
15 1434 206.33.49.126 192.168.1.103 0
16 1434 206.33.49.126 192.168.1.103 0
17 64 192.168.1.103 206.33.49.126 0
18 1434 206.33.49.126 192.168.1.103 0
19 1434 206.33.49.126 192.168.1.103 0
20 1434 206.33.49.126 192.168.1.103 0
21 1434 206.33.49.126 192.168.1.103 0
22 1434 206.33.49.126 192.168.1.103 0
23 64 192.168.1.103 206.33.49.126 0
24 1434 206.33.49.126 192.168.1.103 0
25 1434 206.33.49.126 192.168.1.103 0
26 1434 206.33.49.126 192.168.1.103 0
27 1434 206.33.49.126 192.168.1.103 0
28 1434 206.33.49.126 192.168.1.103 0
29 1434 206.33.49.126 192.168.1.103 0
30 64 192.168.1.103 206.33.49.126 0
31 1434 206.33.49.126 192.168.1.103 0
32 1434 206.33.49.126 192.168.1.103 0
33 1434 206.33.49.126 192.168.1.103 0
34 1082 206.33.49.126 192.168.1.103 1 <------ Packet in question
35 1434 206.33.49.126 192.168.1.103 0
36 1434 206.33.49.126 192.168.1.103 0
37 1434 206.33.49.126 192.168.1.103 0
38 64 192.168.1.103 206.33.49.126 0
39 1434 206.33.49.126 192.168.1.103 0
40 1434 206.33.49.126 192.168.1.103 0
41 1434 206.33.49.126 192.168.1.103 0
42 1434 206.33.49.126 192.168.1.103 0
43 1434 206.33.49.126 192.168.1.103 0
44 1434 206.33.49.126 192.168.1.103 0
45 1434 206.33.49.126 192.168.1.103 0
46 626 206.33.49.126 192.168.1.103 1 200
47 64 192.168.1.103 206.33.49.126 0