Чем идентифицируется логическое tcp соединение
Перейти к содержимому

Чем идентифицируется логическое tcp соединение

  • автор:

Логические соединения — основа надежности TCP

C⅛HόaNbiM отличием TCP От UOP является то, что на протокол ТОР возложена дополнитель- : пая задача—обеспечить надежную доставку сообщений, используя в качестве ос новы йена* ДǾЖl·ί&й Д&ЙTãſp&taMHЫЙ протокол /Р.

На рис. 19.5 показаны сети, соединенные маршрутизаторами, на которых установлен протокол IP. Установленные на конечных узлах протокольные модули TCP решают задачу обеспечения надежного обмена данными путем установления между собой логических соединений. Благодаря логическому соединению TCP следит, чтобы передаваемые сегменты не были потеряны, не были продублированы и пришли к получателю в том порядке, в котором были отправлены.

При установлении логического соединения модули TCP договариваются между собой о параметрах процедуры обмёна данными.

В протоколе TCP каждая сторона соединения посылает противоположной стороне следующие параметры:

? максимальный размер сегмента, который она готова принимать;

? максимальный объем данных (возможно несколько сегментов), которые она разрешает другой стороне передавать в свою сторону, даже если та еще не получила квитанцию на предыдущую порцию данных (размер окна);

? начальный порядковый номер байта, с которого она начинает отсчет потока данных в рамках данного соединения.

В результате переговорного процесса модулей TCP с двух сторон соединения определяются параметры соединения. Одни из них остаются постоянными в течение всего сеанса связи, а другие адаптивно изменяются. В частности, в зависимости от загрузки буфера принимающей стороны, а также надежности работы сети динамически изменяется размер окна отправителя.

Создание соединения означает также выделение операционной системой на каждой стороне соединения определенных системных ресурсов: для организации буферов, таймеров, счетчиков. Эти ресурсы будут закреплены за соединением с момента создания и до момента разрыва.

Логическое ТСР-соединейие однозначно идентифицируется парой ¢ok℮tqo. .

Каждый сокет одновременно может участвовать в нескольких соединениях. Так, если (IP1, nl), (IP2, ∏2), (IPЗ, пЗ) — сокеты трех разных приложений, где IP1,

IP2, IPЗ — их IP-адреса, a nl, п2, пЗ — номера их TCP-портов, то возможно образование следующих соединений:

На рис. 19.6 показаны соединения 1 и 3, образованные сокетом (IP2, п2).

А теперь рассмотрим на примере, как протокол TCP выполняет демультиплексирование. Пусть некий поставщик услуг оказывает услугу по веб-хостингу, то есть на его компьютере клиенты могут устанавливать свои веб-серверы. Веб-сервер основан на протоколе прикладного уровня HTTP, который, в свою очередь, использует протокол TCP. TCP ожидает запросы от веб-клиентов (браузеров), прослушивая хорошо известный порт 80.

На рис. 19.7 показан вариант хостинга с двумя веб-серверами — сервером www1. model.ru, имеющим IP-aдpec IP1, и сервером www2.tour.ru с адресом IP2. К каждому из них может обращаться множество клиентов, причем клиенты могут одновременно работать как с сервером WWW1, так и с сервером WWW2. Работа каждого клиента требует сохранения прочитанных страниц, параметров и настроек сеанса связи, то есть образования отдельного логического соединения. Такое соединение создается протоколом TCP для каждой пары клиент-сервер.

На рисунке показаны два браузера, имеющие соответственно сокеты (IPk, nk) и (IPm, nm). Пользователь браузера к обращается одновременно к серверам WWW1 и WWW2. Наличие отдельных соединений для работы с каждым из этих серверов гарантирует разделение информационных потоков — у пользователя нико- ”та не возникает вопроса, каким сервером ему была послана та или иная страница. Одновременно с пользователем браузера к с сервером WWW2 работает пользователь браузера ш. Ив этом случае отдельные логические соединения,

в рамках которых идет работа обоих пользователей, позволяют изолировать их информационные потоки. На рисунке показаны буферы, количество которых определяется не числом веб-серверов и не числом клиентов, а числом логических соединений. Сообщения в эти буферы направляются в зависимости от значений сокетов как отправителя, так и получателя.

Таким образом, протокол TCP осуществляет демультиплексирование на основе соединений.

Чем идентифицируется логическое tcp соединение

В стеке протоколов TCP/IP протокол TCP (Transmission Control Protocol) работает так же, как и протокол UDP, на транспортном уровне. Он обеспечивает надежную транспортировку данных между прикладными процессами путем установления логического соединения.

Сегменты TCP

Единицей данных протокола TCP является сегмент. Информация, поступающая к протоколу TCP в рамках логического соединения от протоколов более высокого уровня, рассматривается протоколом TCP как неструктурированный поток байт. Поступающие данные буферизуются средствами TCP. Для передачи на сетевой уровень из буфера «вырезается» некоторая непрерывная часть данных, называемая сегментом. В протоколе TCP предусмотрен случай, когда приложение обращается с запросом о срочной передаче данных (бит PSH в запросе установлен в 1). В этом случае протокол TCP, не ожидая заполнения буфера до уровня размера сегмента, немедленно передает указанные данные в сеть. О таких данных говорят, что они передаются вне потока — out of band. Не все сегменты, посланные через соединение, будут одного и того же размера, однако оба участника соединения должны договориться о максимальном размере сегмента, который они будут использовать. Этот размер выбирается таким образом, чтобы при упаковке сегмента в IP-пакет он помещался туда целиком, то есть максимальный размер сегмента не должен превосходить максимального размера поля данных IP-пакета. В противном случае пришлось бы выполнять фрагментацию, то есть делить сегмент на несколько частей, для того, чтобы он вместился в IP-пакет. Аналогичные проблемы решаются и на сетевом уровне. Для того, чтобы избежать фрагментации, должен быть выбран соответствующий максимальный размер IP-пакета. Однако при этом должны быть приняты во внимание максимальные размеры поля данных кадров (MTU) всех протоколов канального уровня, используемых в сети. Максимальный размер сегмента не должен превышать минимальное значение на множестве всех MTU составной сети.

Порты и установление TCP-соединений

  • При установлении соединения одна из сторон является инициатором. Она посылает запрос к протоколу TCP на открытие порта для передачи (active open).
  • После открытия порта протокол TCP на стороне процесса-инициатора посылает запрос процессу, с которым требуется установить соединение.
  • Протокол TCP на приемной стороне открывает порт для приема данных (passive open) и возвращает квитанцию, подтверждающую прием запроса.
  • Для того чтобы передача могла вестись в обе стороны, протокол на приемной стороне также открывает порт для передачи (active port) и также передает запрос к противоположной стороне.
  • Сторона-инициатор открывает порт для приема и возвращает квитанцию. Соединение считается установленным. Далее происходит обмен данными в рамках данного соединения.

Концепция квитирования

В рамках соединения правильность передачи каждого сегмента должна подтверждаться квитанцией получателя. Квитирование — это один из традиционных методов обеспечения надежной связи. Идея квитирования состоит в следующем.

Для того, чтобы можно было организовать повторную передачу искаженных данных отправитель нумерует отправляемые единицы передаваемых данных (далее для простоты называемые кадрами). Для каждого кадра отправитель ожидает от приемника так называемую положительную квитанцию — служебное сообщение, извещающее о том, что исходный кадр был получен и данные в нем оказались корректными. Время этого ожидания ограничено — при отправке каждого кадра передатчик запускает таймер, и если по его истечению положительная квитанция на получена, то кадр считается утерянным. В некоторых протоколах приемник, в случае получения кадра с искаженными данными должен отправить отрицательную квитанцию — явное указание того, что данный кадр нужно передать повторно.

Существуют два подхода к организации процесса обмена положительными и отрицательными квитанциями: с простоями и с организацией «окна».

Метод с простоями требует, чтобы источник, пославший кадр, ожидал получения квитанции (положительной или отрицательной) от приемника и только после этого посылал следующий кадр (или повторял искаженный). Из рисунка 6.1 видно, что в этом случае производительность обмена данными существенно снижается — хотя передатчик и мог бы послать следующий кадр сразу же после отправки предыдущего, он обязан ждать прихода квитанции. Снижение производительности для этого метода коррекции особенно заметно на низкоскоростных каналах связи, то есть в территориальных сетях.

Рис. 6.1. Метод подтверждения корректности передачи кадров с простоем источника

Во втором методе для повышения коэффициента использования линии источнику разрешается передать некоторое количество кадров в непрерывном режиме, то есть в максимально возможном для источника темпе, без получения на эти кадры ответных квитанций. Количество кадров, которые разрешается передавать таким образом, называется размером окна. Рисунок 6.2 иллюстрирует данный метод для размера окна в W кадров. Обычно кадры при обмене нумеруются циклически, от 1 до W. При отправке кадра с номером 1 источнику разрешается передать еще W-1 кадров до получения квитанции на кадр 1. Если же за это время квитанция на кадр 1 так и не пришла, то процесс передачи приостанавливается, и по истечению некоторого тайм-аута кадр 1 считается утерянным (или квитанция на него утеряна) и он передается снова.

Рис. 6.2. Метод «окна» — непрерывная отправка пакетов

Если же поток квитанций поступает более-менее регулярно, в пределах допуска в W кадров, то скорость обмена достигает максимально возможной величины для данного канала и принятого протокола.

Этот алгоритм называют алгоритмом скользящего окна. Действительно, при каждом получении квитанции окно перемещается (скользит), захватывая новые данные, которые разрешается передавать без подтверждения.

Реализация скользящего окна в протоколе TCP

В протоколе TCP реализована разновидность алгоритма квитирования с использованием окна. Особенность этого алгоритма состоит в том, что, хотя единицей передаваемых данных является сегмент, окно определено на множестве нумерованных байт неструктурированного потока данных, поступающих с верхнего уровня и буферизуемых протоколом TCP.

Квитанция посылается только в случае правильного приема данных, отрицательные квитанции не посылаются. Таким образом, отсутствие квитанции означает либо прием искаженного сегмента, либо потерю сегмента, либо потерю квитанции.

В качестве квитанции получатель сегмента отсылает ответное сообщение (сегмент), в которое помещает число, на единицу превышающее максимальный номер байта в полученном сегменте. Если размер окна равен W, а последняя квитанция содержала значение N, то отправитель может посылать новые сегменты до тех пор, пока в очередной сегмент не попадет байт с номером N+W. Этот сегмент выходит за рамки окна, и передачу в таком случае необходимо приостановить до прихода следующей квитанции.

Выбор тайм-аута

Выбор времени ожидания (тайм-аута) очередной квитанции является важной задачей, результат решения которой влияет на производительность протокола TCP.

Тайм-аут не должен быть слишком коротким, чтобы по возможности исключить избыточные повторные передачи, которые снижают полезную пропускную способность системы. Но он не должен быть и слишком большим, чтобы избежать длительных простоев, связанных с ожиданием несуществующей или «заблудившейся» квитанции.

При выборе величины тайм-аута должны учитываться скорость и надежность физических линий связи, их протяженность и многие другие подобные факторы. В протоколе TCP тайм-аут определяется с помощью достаточно сложного адаптивного алгоритма, идея которого состоит в следующем. При каждой передаче засекается время от момента отправки сегмента до прихода квитанции о его приеме (время оборота). Получаемые значения времен оборота усредняются с весовыми коэффициентами, возрастающими от предыдущего замера к последующему. Это делается с тем, чтобы усилить влияние последних замеров. В качестве тайм-аута выбирается среднее время оборота, умноженное на некоторый коэффициент. Практика показывает, что значение этого коэффициента должно превышать 2. В сетях с большим разбросом времени оборота при выборе тайм-аута учитывается и дисперсия этой величины.

Реакция на перегрузку сети

Варьируя величину окна, можно повлиять на загрузку сети. Чем больше окно, тем большую порцию неподтвержденных данных можно послать в сеть. Если сеть не справляется с нагрузкой, то возникают очереди в промежуточных узлах-маршрутизаторах и в конечных узлах-компьютерах.

При переполнении приемного буфера конечного узла «перегруженный» протокол TCP, отправляя квитанцию, помещает в нее новый, уменьшенный размер окна. Если он совсем отказывается от приема, то в квитанции указывается окно нулевого размера. Однако даже после этого приложение может послать сообщение на отказавшийся от приема порт. Для этого, сообщение должно сопровождаться пометкой «срочно» (бит URG в запросе установлен в 1). В такой ситуации порт обязан принять сегмент, даже если для этого придется вытеснить из буфера уже находящиеся там данные.

После приема квитанции с нулевым значением окна протокол-отправитель время от времени делает контрольные попытки продолжить обмен данными. Если протокол-приемник уже готов принимать информацию, то в ответ на контрольный запрос он посылает квитанцию с указанием ненулевого размера окна.

Другим проявлением перегрузки сети является переполнение буферов в маршрутизаторах. В таких случаях они могут централизовано изменить размер окна, посылая управляющие сообщения некоторым конечным узлам, что позволяет им дифференцировано управлять интенсивностью потока данных в разных частях сети.

Формат сообщений TCP

Сообщения протокола TCP называются сегментами и состоят из заголовка и блока данных. Заголовок сегмента имеет следующие поля:

  • Порт источника (SOURS PORT) занимает 2 байта, идентифицирует процесс-отправитель;
  • Порт назначения (DESTINATION PORT) занимает 2 байта, идентифицирует процесс-получатель;
  • Последовательный номер (SEQUENCE NUMBER) занимает 4 байта, указывает номер байта, который определяет смещение сегмента относительно потока отправляемых данных;
  • Подтвержденный номер (ACKNOWLEDGEMENT NUMBER) занимает 4 байта, содержит максимальный номер байта в полученном сегменте, увеличенный на единицу; именно это значение используется в качестве квитанции;
  • Длина заголовка (HLEN) занимает 4 бита, указывает длину заголовка сегмента TCP, измеренную в 32-битовых словах. Длина заголовка не фиксирована и может изменяться в зависимости от значений, устанавливаемых в поле Опции;
  • Резерв (RESERVED) занимает 6 битов, поле зарезервировано для последующего использования;
  • Кодовые биты (CODE BITS) занимают 6 битов, содержат служебную информацию о типе данного сегмента, задаваемую установкой в единицу соответствующих бит этого поля:
  • URG — срочное сообщение;
  • ACK — квитанция на принятый сегмент;
  • PSH — запрос на отправку сообщения без ожидания заполнения буфера;
  • RST — запрос на восстановление соединения;
  • SYN — сообщение используемое для синхронизации счетчиков переданных данных при установлении соединения;
  • FIN — признак достижения передающей стороной последнего байта в потоке передаваемых данных.
  • Окно (WINDOW) занимает 2 байта, содержит объявляемое значение размера окна в байтах;
  • Контрольная сумма (CHECKSUM) занимает 2 байта, рассчитывается по сегменту;
  • Указатель срочности (URGENT POINTER) занимает 2 байта, используется совместно с кодовым битом URG, указывает на конец данных, которые необходимо срочно принять, несмотря на переполнение буфера;
  • Опции (OPTIONS) — это поле имеет переменную длину и может вообще отсутствовать, максимальная величина поля 3 байта; используется для решения вспомогательных задач, например, при выборе максимального размера сегмента;
  • Заполнитель (PADDING) может иметь переменную длину, представляет собой фиктивное поле, используемое для доведения размера заголовка до целого числа 32-битовых слов.

Логические соединения — основа надежности TCP

Основным отличием TCP от UDP является то, что на протокол TCP возложена дополнительная задача — обеспечить надежную доставку сообщений, используя в качестве основы ненадежный дейтаграммный протокол IP.

Для решения этой задачи протокол TCP использует метод продвижения данных с установлением логического соединения. Как было сказано ранее, логическое соединение дает возможность участникам обмена следить за тем, чтобы данные не были потеряны, искажены или продублированы, а также чтобы они пришли к получателю в том порядке, в котором были отправлены.

Протокол TCP устанавливает логические соединения между прикладными процессами, причем в каждом соединении участвуют только два процесса. TCP-соединение является дуплексным, то есть каждый из участников этого соединения может одновременно получать и отправлять данные.

На рис. 17.6 показаны сети, соединенные маршрутизаторами, на которых установлен протокол IP. Установленные на конечных узлах протокольные модули TCP решают задачу обеспечения надежного обмена данными путем установления между собой логических соединений.

Рис. 17.6. TCP-соединение создает надежный логический канал между конечными узлами

При установлении логического соединения модули TCP договариваются между собой о параметрах процедуры обмена данными. В протоколе TCP каждая сторона соединения посылает противоположной стороне следующие параметры:

□ максимальный размер сегмента, который она готова принимать;

□ максимальный объем данных (возможно несколько сегментов), которые она разрешает другой стороне передавать в свою сторону, даже если та еще не получила квитанцию на предыдущую порцию данных (размер окна);

□ начальный порядковый номер байта, с которого она начинает отсчет потока данных в рамках данного соединения.

В результате переговорного процесса модулей TCP с двух сторон соединения определяются параметры соединения. Одни из них остаются постоянными в течение всего сеанса связи, а другие адаптивно изменяются. В частности, в зависимости от загрузки буфера принимающей стороны, а также надежности работы сети динамически изменяется размер окна отправителя.

Соединение устанавливается по инициативе клиентской части приложения. При необходимости выполнить обмен данными с серверной частью приложение-клиент обращается к нижележащему протоколу TCP, который в ответ на это обращение посылает сегмент-запрос на установление соединения протоколу TCP, работающему на стороне сервера (рис. 17.7, а).

Рис. 17.7. Процедура установления и разрыва логического соединения при нормальном течении процесса

В числе прочего в запросе содержится флаг SYN, установленный в 1. Получив запрос, модуль TCP на стороне сервера пытается создать «инфраструктуру» для обслуживания нового клиента. Он обращается к операционной системе с просьбой о выделении определенных системных ресурсов для организации буферов, таймеров, счетчиков. Эти ресурсы закрепляются за соединением с момента создания и до момента разрыва. Если на стороне сервера все необходимые ресурсы были получены и все необходимые действия выполнены, то модуль TCP посылает клиенту сегмент с флагами АСК и SYN.

В ответ клиент посылает сегмент с флагом АСК и переходит в состояние установленного логического соединения (состояние ESTABLISHED). Когда сервер получает флаг АСК, он также переходит в состояние ESTABLISHED. На этом процедура установления соединения заканчивается, и стороны могут переходить к обмену данными. Соединение может быть разорвано в любой момент по инициативе любой стороны. Для этого клиент и сервер должны обменяться сегментами FIN и АСК, в последовательности, показанной на рис. 17.7, б (здесь инициатором является клиент). Соединение считается закрытым по прошествии некоторого времени, в течение которого сторона-инициатор убеждается, что ее завершающий сигнал АСК дошел нормально и не вызвал никаких «аварийных» сообщений со стороны сервера.

Мы описали здесь процедуры установления и закрытия соединения очень схематично. Реальные протокольные модули работают в соответствии с гораздо более сложными алгоритмами, учитываю­щими всевозможные «нештатные» ситуации, такие, например, как задержки и потери сегментов, недостаточность ресурсов или неготовность сервера к установлению соединения. Кроме того, мы проигнорировали тот факт, что еще на этапе установления соединения стороны договариваются о некоторых параметрах своего взаимодействия, например о начальных номерах посылаемых ими байтов. Однако мы скоро вернемся к этим важным деталям работы протокола TCP.

Логическое TCP-соединение однозначно идентифицируется парой сокетов, определенных для этого соединения двумя взаимодействующими процессами.

Сокет одновременно может участвовать в нескольких соединениях. Так, на рис. 17.8 показаны три компьютера с адресами IPI, IP2, IP3. На каждом компьютере выполняется по одному приложению — APPL1, APPL2 и APPL3, сокеты которых — соответственно (IP1, nl), (IP2, n2), (IP3, n3), а номера TCP-портов приложений — nl, n2, n3.

Рис. 17.8. Один cокет может участвовать в нескольких соединениях

На рисунке показаны два логических соединения, которое установило приложение 2 с приложением 1 и приложением 3. Логические соединения идентифицируются как <(IP2, n2), (IP1, nl)>и <(IP2, n2), (IP3, n3)>соответственно. Мы видим, что в обоих соединениях участвует один и тот же сокет — (IP2, n2).

А теперь рассмотрим на примере, как протокол TCP выполняет демультиплексирование. Пусть некий поставщик услуг оказывает услугу по веб-хостингу, то есть на его компьютере клиенты могут разворачивать свои веб-серверы. Веб-сервер основан на протоколе прикладного уровня HTTP, который передает свои сообщения в TCP-сегментах. Модуль TCP ожидает запросы от веб-клиентов (браузеров), «прослушивая» хорошо известный порт 80.

На рис. 17.9 показан вариант хостинга с двумя веб-серверами — сервером wwwl.model.ru, имеющим IP-адрес IP1, и сервером www2.tour.ru с адресом IP2.

К каждому из них может обращаться множество клиентов, причем клиенты могут одновременно работать как с сервером wwwl, так и с сервером www2. Для каждой пары клиент-сервер протоколом TCP создается отдельное логическое соединение.

Рис. 17.9. Демультиплексирование протокола TCP на основе соединений

На рисунке показаны два браузера, имеющие соответственно сокеты (IPk, nk) и (IPm, nm). Пользователь браузера k обращается одновременно к серверам WWW1 и WWW2. Наличие отдельных соединений для работы с каждым из этих серверов обеспечивает не только надежную доставку, но и разделение информационных потоков — у пользователя никогда не возникает вопроса, каким сервером ему была послана та или иная страница. Одновременно с пользователем браузера k с сервером WWW2 работает пользователь браузера m. И в этом случае отдельные логические соединения, в рамках которых идет работа обоих пользователей, позволяют изолировать их информационные потоки. На рисунке показаны буферы, количество которых определяется не числом веб-серверов и не числом клиентов, а числом логических соединений. Сообщения в эти буферы направляются в зависимости от значений сокетов как отправителя, так и получателя. Отсюда можно сделать вполне конкретный вывод.

Протокол TCP осуществляет демультиплексирование информации, поступающей на прикладной уровень, на основе соединений процессов или, что одно и то же, на основе идентифицирующих эти процессы пар сокетов.

studopedia.org — Студопедия.Орг — 2014-2024 год. Студопедия не является автором материалов, которые размещены. Но предоставляет возможность бесплатного использования (0.008 с) .

Как протокол TCP идентифицирует логические соединения?

Author24 — интернет-сервис помощи студентам

«Протокол TCP осуществляет демультиплексирование информации, поступающей на прикладной уровень, на основе соединений процессов или, что одно и тоже, на основе идентифицирующих эти процессы пар сокетов.»

Так, а что такое сокет? А это пара IP-адрес+ порт

То есть к TCP протоколу пришла инфа. Он должен в ней распознать

1)порт отправителя
2)порт получателя
3)IP-адрес отправителя
4)IP-адрес получателя

Эти четыре данные дадут два сокета-уникальное соединение, с которым TCP сопоставит буфер и запихает туда данные. А дальше уже прикладная задача из буфера будет читать. (всё это я в книжке прочёл)

Только вот закавыка какая. Не может TCP-протокол распознать IP адреса из пришедших ему данных (сегментами которые называются). Вот заголовок TCP-сегмента:

Нету там ни IP-адреса получателя, ни IP-адреса отправителя (а порты есть- два первых поля). Так как же TCP-протокол распознаёт пришедшие к нему данные? Спасибо, кто откликнется.

94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
Ответы с готовыми решениями:

Реализовать на tcp сокетах переподключение к tcp серверу в случае потери соединения
Всем привет, подскажите как можно реализовать на tcp сокетах переподключение к tcp серверу в случае.

Как происходит получение данных через протокол TCP
Имеется клиент-серверное приложение: using System; using System.Collections.Generic; using.

Как можно узнать через VBA , есть ли tcp/ip протокол.
если есть, то как можно узнать , локальный ip адресс.

Как создать локальную сеть через протокол TCP\IPv6?
как создать локальную сеть через протокол TCP\IPv6? ДАНО: роутер D-LINK DIR-300 rev. B7, интернет.

быдлокодер
1724 / 911 / 106
Регистрация: 04.06.2008
Сообщений: 5,678
Ну что, ребята, будут какие-нибудь мнения по этому вопросу?
224 / 112 / 18
Регистрация: 27.09.2012
Сообщений: 575
Для начала нужно создать TCP сессию. Данные идут с третьего уровня. Что мешает ему взять их от туда.
быдлокодер
1724 / 911 / 106
Регистрация: 04.06.2008
Сообщений: 5,678

Изъясняйтесь яснее. С какого третьего? Ниже TCP лежит IP протокол и в заголовке IP-пакета действительно прописан IP-адрес отправителя. Но TCP-потоколу он недоступен.

Что касается того, что там лежит выше, то проведём небольшой эксперимент. Командуем:

telnet pop.mail.ru 110

На консоли замелькает всякая фигня, оканчивающаяся +OK, соединение с сервером pop.mail.ru установлено. С этим сервером надо переговариваться определёнными командами. Но мы сразу нажмём на Entet и получим:

-ERR invalid command

pop.mail.ru безошибочно определил, что именно с моего IP-адреса была послана некорректная команда. А если мы задействуем (по другому никак) сниффер и перехватим TCP-сегменты, формирующиеся при нажатии Enter, то получим такую картинку (это TCP-сегмент):

(Над TCP находится IP-заголовок, но сюда TCP-протокол не лезет)
11 96 00 6E 1F 68 49 6D 08 91 66 CB 50 18 FF E4 D4 D9 00 00 0D 0A
(внизу TCP-сегмента ничего нет!)

(Ну или поменять местами поясняющие надписи, это не суть важно- верх низ или чё там).

Всё, если побайтно разобрать его, то можно увидеть знакомые поля. К примеру 00 6E- это 110 (порт принимателя), а два последних байта 0D 0A- это тот самый Enter и есть (перевод каретки и новая строка)

Но тут нет моего IP-адреса, вот в чём дело! Но распознаётся он безошибочно-в ответ на это вот придёт TCP-сегмент с содержанием последних байтов -ERR invalid command. Такие дела. Почему так?

Только пожалуйста, без пускания пыли в глаза. Всякие новые непонятные термины типа «третий уровень» и я вводить могу.

Эксперт Java

3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220

Ну так и IP, например, мак-адреса не доступны, однако ж данные как-то ходят. Не иначе как чудеса.

быдлокодер
1724 / 911 / 106
Регистрация: 04.06.2008
Сообщений: 5,678

ЦитатаСообщение от xoraxax Посмотреть сообщение

Ну так и IP, например, мак-адреса не доступны, однако ж данные как-то ходят. Не иначе как чудеса.

зачем слова говорить? Если у меня возникнет такой вопрос, я его задам. Пока же- он неплохо объяснён у тех же Олиферов в главе «Пример взаимодействия протоколов IP, ARP, Ethernet и DNS». Вопрос открыт. И хорош уже отбрехиваться ссылками.

Эксперт Java

3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220

Ну так почитайте как работает OSI. Если вам понятно каким образом уровень IP взаимодействует с L2, почему вам не понятно как TCP взаимодействует с IP?

быдлокодер
1724 / 911 / 106
Регистрация: 04.06.2008
Сообщений: 5,678

Я читал, мне непонятна одна деталь. Я её обрисовал донельзя конкретно, готов уточнить. Форум для того и существует, чтобы разъяснять подобные непонятные вопросы. Тупо перенаправлять к поиску я сам могу. Спасибо за внимание и не беспокойтесь больше. Вопрос открыт. И да, второй раз говорю- хорош уже терминами непонятными щеголять.

224 / 112 / 18
Регистрация: 27.09.2012
Сообщений: 575

В моделе оси 7 уровней их считают снищу вверх.
Я говорил про третий «сетевой».
Происходит всё так:
На первом физическом уровне получаешь биты и собираешь их в кучу. И передаешь на второй уровень в виде кадра и комп проверяет его ли MAC адрес в заголовке получателя, если его то отправляет на третий уровень «сетевой» убирает заголовок. Там проверяет ему ли прислали пакет по IP адресу. И есть ли TCP соединение. Если всё нормально то отбрасывается заголовок и сегмент идет вверх ну и там уже порты. А обратно он отправляет в установленное TCP соединение.
Так что 4 уровню «транспортному» пофигу откуда, ему нужны только порты куда пришло и куда отправлять.

быдлокодер
1724 / 911 / 106
Регистрация: 04.06.2008
Сообщений: 5,678

ЦитатаСообщение от kroniel Посмотреть сообщение

Если всё нормально то отбрасывается заголовок и сегмент идет вверх ну и там уже порты.

вот именно. Наверх это TCP-уровень, куда и идут ТОЛЬКО (пример TCP-сегмента я привёл) порты. А у меня в книге чёрным по-белому написано, что TCP идентифицирует сегмент по порту+IP-адресу

Второй раз спрашиваю- откуда на TCP уровне IP-адреса, если вы сами сказали, что к нему идут порты (в том смысле, что ОДНИ порты, без IP-адресов)?

Эксперт Java

3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220

Вам в десятый раз уже объясняют, что если рассматривать конкретно TCP изолированно от других уровней стэка TCP/IP то там нет ip адресов вообще, они совершенно не имеют никакого значения для TCP. IP адресами занимается IP уровень. С другой стороны, получаемые данные можно рассматривать одним куском примерно так: |L2header|L3header|L4header|data|. Каждый уровень занимается своими делами. Есть отдельный обработчик L2, есть отдельный обработчик IP, есть отдельный же обработчик для TCP, есть для UDP, есть для telnet и, например, почты, а кроме того есть, к примеру, текстовые редакторы, в которых вы составляете свои письма. Вы когда письмо отправляете вы заморачиваетесь портами, ip или mac адресами? Конечно же нет, вы указываете почтовый адрес, ну а дальше tcp вставляет заголовок с номером порта, ip — c ip-адресом, ehternet — c мак-адресом, все это кодируется высокими и низкими уровнями и на другой стороне разбирается в такой же последовательности.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *