
- •1 Эволюция вычислительных систем
- •2 Вычислительные сети
- •3 Топология физических связей
- •4 Адресация компьютеров
- •5 Модель osi
- •6 Уровни модели osi
- •7 Стек tcp/ip
- •8 Стек ipx/spx
- •10 Локальные и глобальные сети
- •11 Типы линий связи
- •12 Стандарты кабелей
- •13 Методы передачи дискретных данных на физическом уровне
- •14 Передача данных на физическом уровне. Цифровое кодирование
- •17 Биполярный импульсный код
- •18 Логическое кодирование
- •19 Дискретная модуляция аналоговых сигналов
- •20 Асинхронная передача.
- •21 Синхронная передача: понятие использование, синхронные протоколы.
- •24 Методы коммутации
- •25 Коммутация каналов
- •26 Коммутация пакетов
- •27 Общая характеристика протоколов локальных сетей
- •28 Протоколы llc
- •29 Технология Ethernet
- •30 Метод доступа csma/cd
- •31 Форматы кадров технологии Ethernet
- •35 Технология Token Ring (802.5)
- •36 Технология fddi
- •37 Fast Ethernet
- •38 Высокоскоростная технология Gigabit Ethernet
- •39 Структурная кабельная система, применяемая в сетевых технологиях
- •40 Концентраторы и сетевые адаптеры
- •41 Использвание мостов и коммутаторов
- •42 Коммутаторы локальных сетей
- •43 Алгоритм работы прозрачного моста
- •44 Мосты с маршрутизацией от источника
- •45 Техническая реализация и дополнительные функции коммутаторов
- •46 Виртуальные локальные сети
- •47 Принципы маршрутизации
- •48 Организация межсетевого взаимодействия средствами tcp/ip
- •49 Адресация в ip-сетях
- •50 Система доменных имен dns
- •51 Протокол ip
- •52 Протокол tcp-сообщений
- •53 Протоколы маршрутизации в ip-сетях
- •54 Общая характеристика протокола ipx
- •55 Маршрутизаторы
- •56 Глобальные сети
- •57Огранизация глобальных связей на основе выделенных каналов:аналоговые линии
- •58 Огранизация глобальных связей на основе выделенных каналов: цифровые линии
- •59 Протоколы канального уровня для выделенных линий
- •60 Глобальные связи на основе сетей с коммутацией каналов
- •61 Isdn — сети с интегральными услугами
- •62 Стек протоколов и структура сети isdn
- •63 Компьютерные глобальные сети с коммутацией пакетов
- •64 Сети х.25
- •65 Сети Frame Relay
- •66 Технология atm
- •67 Удаленный доступ
- •68 Управление сетями: функции, задачи, архитектура
- •69 Управление сетями:стандарты, протоколы
- •7.2.1. Стандартизуемые элементы системы управления
- •70 Мониторинг и анализ локальных сетей
- •7.3.2. Анализаторы протоколов
- •7.3.3. Сетевые анализаторы
51 Протокол ip
Протокол IP позволяет выполнять фрагментацию пакетов, поступающих на входные порты маршрутизаторов.
Следует различать фрагментацию сообщений в узле-отправителе и динамическую фрагментацию сообщений в транзитных узлах сети — маршрутизаторах. Практически во всех стеках протоколов есть протоколы, которые отвечают за фрагментацию сообщений прикладного уровня на такие части, которые укладываются в кадры канального уровня. В стеке TCP/IP эту задачу решает протокол TCP, который разбивает поток байтов, передаваемый ему с прикладного уровня на сообщения нужного размера. А вот при необходимости передать пакет в следующую сеть, для которой размер пакета является слишком большим, IP-фрагментация становится необходимой. IP-пакет может быть помечен как не фрагментируемый. Любой пакет, помеченный таким образом, не может быть фрагментирован модулем IP ни при каких условиях. Если же пакет, помеченный как не фрагментируемый, не может достигнуть получателя без фрагментации, то этот пакет просто уничтожается, а узлу-отправителю посылается соответствующее ICMP-сообщение.
Процедуры фрагментации и сборки протокола IP рассчитаны на то, чтобы пакет мог быть разбит на практически любое количество частей, которые впоследствии могли бы быть вновь собраны. Поле смещения фрагмента сообщает получателю положение фрагмента в исходном пакете. Смещение фрагмента и длина определяют часть исходного пакета, принесенную этим фрагментом.
Чтобы разделить на фрагменты большой пакет, модуль протокола IP, установленный, например, на маршрутизаторе, создает несколько новых пакетов и копирует содержимое полей IP-заголовка из большого пакета в IP-заголовки всех новых пакетов. Данные из старого пакета делятся на соответствующее число частей, размер каждой из которых, кроме самой последней, обязательно должен быть кратным 8 байт. Размер последней части данных равен полученному остатку. Каждая из полученных частей данных помещается в новый пакет. Когда происходит фрагментация, то некоторые параметры IP-заголовка копируются в заголовки всех фрагментов, а другие остаются лишь в заголовке первого фрагмента.
Отметим, что IP-маршрутизаторы не собирают фрагменты пакетов в более крупные пакеты, даже если на пути встречается сеть, допускающая такое укрупнение. Это связано с тем, что отдельные фрагменты сообщения могут перемещаться по интерсети по различным маршрутам, поэтому нет гарантии, что все фрагменты проходят через какой-либо промежуточный маршрутизатор на их пути.
52 Протокол tcp-сообщений
Протокол IP является дейтаграммным протоколом и поэтому по своей природе не может гарантировать надежность передачи данных. Эту задачу — обеспечение надежного канала обмена данными между прикладными процессами в составной сети — решает протокол TCP (Transmission Control Protocol), относящийся к транспортному уровню.
Протокол TCP работает непосредственно над протоколом IP и использует для транспортировки своих блоков данных потенциально ненадежный протокол IP. Надежность передачи данных протоколом TCP достигается за счет того, что он основан на установлении логических соединений между взаимодействующими процессами. До тех пор пока программы протокола TCP продолжают функционировать корректно, а составная сеть не распалась на несвязные части, ошибки в передаче данных на уровне протокола IP не будут влиять на правильное получение данных.
Протокол IP используется протоколом TCP в качестве транспортного средства. Перед отправкой своих блоков данных протокол TCP помещает их в оболочку IP-пакета. При необходимости протокол IP осуществляет любую фрагментацию и сборку блоков данных TCP, требующуюся для осуществления передачи и доставки через множество сетей и промежуточных шлюзов.
Порты
Пакеты, поступающие на транспортный уровень, организуются операционной системой в виде множества очередей к точкам входа различных прикладных процессов. В терминологии TCP/IP такие системные очереди называются портами. Таким образом, адресом назначения, который используется протоколом TCP, является идентификатор (номер) порта прикладной службы. Номер порта в совокупности с номером сети и номером конечного узла однозначно определяют прикладной процесс в сети. Этот набор идентифицирующих параметров имеет название сокет (socket).
Локальное присвоение номера порта заключается в том, что разработчик некоторого приложения просто связывает с ним любой доступный, произвольно выбранный числовой идентификатор, обращая внимание на то, чтобы он не входил в число зарезервированных номеров портов. В дальнейшем все удаленные запросы к данному приложению от других приложений должны адресоваться с указанием назначенного ему номера порта.
Протокол TCP ведет для каждого порта две очереди: очередь пакетов, поступающих в данный порт из сети, и очередь пакетов, отправляемых данным портом в сеть. Процедура обслуживания протоколом TCP запросов, поступающих от нескольких различных прикладных служб, называется мультиплексированием. Обратная процедура распределения протоколом TCP поступающих от сетевого уровня пакетов между набором высокоуровневых служб, идентифицированных номерами портов, называется демультиплексированием.
Единицей данных протокола TCP является сегмент. Информация, поступающая к протоколу TCP в рамках логического соединения от протоколов более высокого уровня, рассматривается протоколом TCP как неструктурированный поток байтов. Поступающие данные буферизуются средствами TCP. Для передачи на сетевой уровень из буфера «вырезается» некоторая непрерывная часть данных, которая и называется сегментом.
Для организации надежной передачи данных предусматривается установление логического соединения между двумя прикладными процессами. Поскольку соединения устанавливаются через ненадежную коммуникационную систему, основанную на протоколе IP, то во избежание ошибочной инициализации соединений используется специальная многошаговая процедура подтверждения связи.
Формально соединение можно определить как набор параметров, характеризующий процедуру обмена данными между двумя процессами.