Изменения документа TCP
Редактировал(а) Alexandr Fokin 2022/12/12 12:13
отредактировано Alexandr Fokin
на 2022/07/09 17:24
на 2022/07/09 17:24
отредактировано Alexandr Fokin
на 2022/07/09 16:44
на 2022/07/09 16:44
Изменить комментарий:
К данной версии нет комментариев
Комментарий
-
Свойства страницы (1 изменено, 0 добавлено, 0 удалено)
Подробности
- Свойства страницы
-
- Содержимое
-
... ... @@ -1,31 +3,21 @@ 1 -**Transmission Control Protocol** 2 - 3 3 ---- 4 4 5 -**Основные моменты:**3 +**Основные понятия:** 6 6 7 -|(% style="width:215px" %)**Понятие**|(% style="width:1307px" %)**Описание** 8 -|(% style="width:215px" %) |(% style="width:1307px" %)((( 5 +|(% style="width:546px" %) |(% style="width:960px" %)((( 9 9 Основывается на протоколе IP для передачи и маршрутизации. 10 - TCP сегмент заворачивается в IP пакет.7 +Сегмент заворачивается в IP пакет. 11 11 ))) 12 -|(% style="width:215px" %)Сегмент|(% style="width:1307px" %)Блок единичного пакета/сообщения. 13 -Сегмент содержит данные и заголовок необходимой для работы информацией. 14 -|(% style="width:215px" %)Клиент и Сервер|(% style="width:1307px" %)TCP сервер слушает определенный сокет (привязка к IpAddress + Port). 9 +|(% style="width:546px" %)Сегмент|(% style="width:960px" %)Блок единичного пакета/сообщения. 10 +|(% style="width:546px" %)Клиент и Сервер|(% style="width:960px" %)TCP сервер слушает определенный сокет (привязка к IpAddress + Port). 15 15 TCP клиент подключается к серверу, устанавливается соединение. 16 -|(% style="width: 215px" %)Логическое соединение|(% style="width:1307px" %)(((12 +|(% style="width:546px" %)Логическое соединение|(% style="width:960px" %)((( 17 17 Между 2 сторонами устанавливается логическое соединение, в рамках которого идет передача данных. 18 18 19 -При этом соединение само по себе не имеет механизмов для определения разрыва сети, падения приложения одной из сторон или падения хоста. В некоторых случаях имеет смысл реализации пульса для отслеживания состояния соединения. 20 - 21 -Взаимодействие 22 - 23 -1. Установка соединения 24 -1. Обмен данными. 25 -1. Закрытие соединения. 15 +При этом соединение само по себе не имеет механизмов для определения разрыва сети, падения приложения одной из сторон или падения сервера. 26 26 ))) 27 -|(% style="width: 215px" %)Потоковая(stream) передача|(% style="width:1307px" %)(((28 - Данныераскладываютсявtcp сегменты,но стороныоперируетинтерфейсамив виде потока байт.17 +|(% style="width:546px" %)Потоковый (stream) передача|(% style="width:960px" %)((( 18 +Отправка и получение данных идут в виде потока байт. 29 29 30 30 Необходима реализация механизмов для определения границ сообщения в передаваемых данных 31 31 ( ... ... @@ -35,29 +35,13 @@ 35 35 36 36 ) 37 37 ))) 38 -|(% style="width:215px" %)Гарантия доставки сегментов.|(% style="width:1307px" %)((( 39 -При отправке данных (сегментов) каждая сторона фиксирует статус отправки и ожидает подтверждения. Если подтверждение не происходит в течении определенного времени, то один или группа сегментов (зависит от реализации) посылается повторно. 28 +|(% style="width:546px" %)Гарантия доставки сегментов.|(% style="width:960px" %)При отправке данных (сегментов) каждая сторона фиксирует статус отправки и ожидает подтверждения. Если подтверждение не происходит в течении определенного времени, то один или группа сегментов (зависит от реализации) посылается повторно. 29 +|(% style="width:546px" %)Гарантия порядка получения (за счет нумерации данных)|(% style="width:960px" %)В метаданные сегмента записывается порядковый номер первого байта данных, который используется принимающей стороной для восстановления последовательности сегментов (т.к. они могут быть получены не в том порядке, в котором было отправлены). 30 +|(% style="width:546px" %)Гарантия целостности данных за счет контрольной суммы|(% style="width:960px" %)Перед отправкой в метаданные сегмента включается блок с контрольной суммой данных. При получении сегмента, контрольная сумма сверяется для проверки изменения содержимого сегмента. 31 +|(% style="width:546px" %)Окно приема|(% style="width:960px" %) 32 +|(% style="width:546px" %)Окно передачи|(% style="width:960px" %) 40 40 41 -Возможно ситуация, когда сегмент подтверждения может быть утерян (или же еще не успел прийти), и сегмент будет выслан повторно, но такое поведение не приведет к повреждению передаваемых данных. 42 42 43 -Отметим, что возможна ситуация, когда сегменты достигли клиента, отправитель получил подтверждение, но приложение или хост упали, не выполнив окончательную обработку данных из этих сегментов. 44 -))) 45 -|(% style="width:215px" %)Гарантия порядка получения 46 -(за счет нумерации данных)|(% style="width:1307px" %)((( 47 -В заголовок сегмента записывается порядковый номер первого байта данных, который используется принимающей стороной для восстановления последовательности сегментов (т.к. они могут быть получены не в том порядке, в котором было отправлены). 48 - 49 -Также важно, что одно логическое сообщение приложение может быть разбито на несколько TCP сегментов, которые физически дойдет до получателя не в том порядке, в котором были отправлены, но их порядок будет восстановлен на стороне получателя при передаче в поток чтения. 50 -))) 51 -|(% style="width:215px" %)Гарантия целостности данных 52 -(за счет контрольной суммы)|(% style="width:1307px" %)Перед отправкой в заголовок сегмента включается блок с контрольной суммой данных. При получении сегмента, контрольная сумма сверяется для проверки изменения содержимого сегмента. 53 -|(% style="width:215px" %)Окно приема|(% style="width:1307px" %)Можно представить в виде некоторого буфера двигающегося вдоль данных по мере их приема. 54 -Если сегмент не попадает в окно приема, то он отбрасывается. 55 -Если сегмент приходит повторно (данный сегмент уже получен), то он отбрасывается. 56 -Если сегмент попадает в окно приема, но не является следующим по порядку, то он буферизуется, до того момента, как будут получены расположенные по порядку перед ним сегменты (и будет выведен в поток чтения после них). 57 -|(% style="width:215px" %)Окно передачи|(% style="width:1307px" %)Можно представить в виде некоторого буфера двигающегося вдоль данных по мере их передачи. 58 -Определяет, какие сегменты можно отправить в текущий момент времени. 59 -Также в рамках него контролируются статус сегментов (было ли получено подтверждение о получении). 60 - 61 61 ---- 62 62 63 63