Лекция 29,30 Протоколы: основные понятия и принципы взаимодействия. Стек протоколов. Принцип работы протоколов.
Согласованный набор протоколов разных уровней, достаточный для организации межсетевого взаимодействия, называется стеком протоколов.
Для каждого уровня определяется набор функций-запросов для взаимодействия с вышележащим уровнем, который называется интерфейсом.
Правила взаимодействия двух машин могут быть описаны в виде набора процедур для каждого из уровней, которые называются протоколами.
Стеки протоколов разбиваются на три уровня:
- сетевые;
- транспортные;
- прикладные.
Сетевые протоколы предоставляют следующие услуги: адресацию и маршрутизацию информации, проверку на наличие ошибок, запрос повторной передачи и установление правил взаимодействия в конкретной сетевой среде. Ниже приведены наиболее популярные сетевые протоколы.
- DDP (Datagram Delivery Protocol, протокол доставки дейтаграмм). Протокол передачи данных Apple, используемый в Apple Talk.
- IP (Internet Protocol, протокол Internet). Протокол стека TCP/IP, обеспечивающий адресную информацию и информацию о маршрутизации.
- IPX (Internetwork Packet eXchange, межсетевой обмен пакетами) в NWLink. Протокол Novel NetWare, используемый для маршрутизации и направления пакетов.
- NetBEUI (NetBIOS Extended User Interface, расширенный пользовательский интерфейс базовой сетевой системы ввода вывода). Разработанный совместно IBM и Microsoft, этот протокол обеспечивает транспортные услуги для NetBIOS.
Транспортные протоколы предоставляют следующие услуги надежной транспортировки данных между компьютерами. Ниже приведены наиболее популярные транспортные протоколы.
- ATP (Apple Talk Protocol, транзакционный протокол Apple Talk) и NBP (Name Binding Protocol, протокол связывания имен). Сеансовый и транспортный протоколы Apple Talk.
- NetBIOS (Network Basis Input/Output System, базовая сетевая система ввода вывода). NetBIOS устанавливает соединение между компьютерами, а NetBEUIпредоставляет услуги передачи данных для этого соединения.
- SPX (Sequenced Packet eXchange, последовательный обмен пакетами) в NWLink. Протокол Novel NetWare, используемый для обеспечения доставки данных.
- TCP (Transmission Control Protocol, протокол управления передачей). Протокол стека TCP/IP отвечает за надежную доставку данных.
Прикладные протоколы отвечают за взаимодействие приложений. Ниже приведены наиболее популярные прикладные протоколы.
- AFP (Apple Talk File Protocol, файловый протокол Apple Talk). Протокол удаленного управления файлами Macintosh.
- FTP (File Transfer Protocol, протокол передачи файлов). Протокол стека TCP/IP, используемый для обеспечения услуг по передачи файлов.
- NCP (NetWare Core Protocol, базовый протокол NetWare). Оболочка и редиректоры клиента Novel NetWare.
- SNMP (Simple Network Management Protocol, простой протокол управления сетью). Протокол стека TCP/IP, используемый для управления и наблюдения за сетевыми устройствами.
- HTTP (Hyper Text Transfer Protocol) – протокол передачи гипертекста и другие протоколы.
Архитектура стека протоколов Microsoft TCP/IP.
Набор многоуровневых протоколов, или как называют стек TCP/IP, предназначен для использования в различных вариантах сетевого окружения.
Стек TCP/IP с точки зрения системной архитектуры соответствует эталонной модели OSI (Open Systems Interconnection, взаимодействие открытых систем) и позволяет обмениваться данными по сети приложениям и службам, работающим практически на любой платформе, включая Unix, Windows, Macintosh и другие.
Стандартная реализация TCP/IP (на примере фирмы Microsoft) соответствует четырехуровневой модели вместо семиуровневой модели
Модель TCP/IP включает большее число функций на один уровень, что приводит к уменьшению числа уровней. В модели используются следующие уровни:
- уровень Приложения модели TCP/IP соответствует Прикладному, Представительскому и Сеансовому уровням модели OSI;
- Транспортный уровень модели TCP/IP соответствует аналогичному уровню модели OSI;
- Межсетевой уровень модели TCP/IP выполняет те же функции, что и Сетевой уровень модели OSI;
- уровень Сетевого интерфейса модели TCP/IP соответствует Канальному и Физическому уровням модели OSI.
На физическом и канальном уровнях стек OSI поддерживает спецификации Ethernet,
Token Ring, FDDI, а также протоколы LLC, X.25 и ISDN. На сетевом уровне
реализованы протоколы, как без установления соединений, так и с установлением
соединений. Транспортный протокол стека OSI скрывает различия между сетевыми
сервисами с установлением соединения и без установления соединения, так что
пользователи получают нужное качество обслуживания независимо от нижележащего
сетевого уровня. Чтобы обеспечить это, транспортный уровень требует, чтобы
пользователь задал нужное качество обслуживания. Определены 5 классов
транспортного сервиса, от низшего класса 0 до высшего класса 4, которые
отличаются степенью устойчивости к ошибкам и требованиями к восстановлению
данных после ошибок. Сервисы прикладного уровня включают передачу файлов, эмуляцию
терминала, службу каталогов и почту. Из них наиболее перспективными являются
служба каталогов (стандарт Х.500), электронная почта (Х.400), протокол
виртуального терминала (VT), протокол передачи, доступа и управления файлами
(FTAM), протокол пересылки и управления работами (JTM). В последнее время ISO
сконцентрировала свои усилия именно на сервисах верхнего уровня.
Архитектура стека протоколов Microsoft TCP/IP Набор многоуровневых протоколов,
или как называют стек TCP/IP, предназначен для использования в различных
вариантах сетевого окружения. Стек TCP/IP с точки зрения системной архитектуры
соответствует эталонной модели OSI (Open Systems Interconnection –
взаимодействие открытых систем) и позволяет обмениваться данными по сети
приложениям и службам, работающим практически на любой платформе, включая Unix,
Windows, Macintosh и другие. Реализация TCP/IP фирмы Microsoft соответствует
четырехуровневой модели вместо семиуровневой модели, как показано на рис Модель
TCP/IP включает большее число функций на один уровень, что приводит к
уменьшению числа уровней. В модели используются следующие уровни: уровень
Приложения модели TCP/IP соответствует уровням Приложения, Представления и
Сеанса модели OSI; уровень Транспорта модели TCP/IP соответствует аналогичному
уровню Транспорта модели OSI; межсетевой уровень модели TCP/IP выполняет те же
функции, что и уровень Сети модели OSI; уровень сетевого интерфейса модели
TCP/IP соответствует Канальному и Физическому уровням модели OSI.
Уровень Приложения Через уровень Приложения модели TCP/IP приложения и службы получают доступ к сети. Доступ к протоколам TCP/IP осуществляется посредством двух программных интерфейсов (API – Application Programming Interface):
–Сокеты Windows;
–NetBIOS.
Интерфейс сокетов Windows, или как его называют WinSock, является сетевым программным интерфейсом, предназначенным для облегчения взаимодействия между различными TCP/IP – приложениями и семействами протоколов. Интерфейс NetBIOS используется для связи между процессами (IPC – Interposes Communications) служб и приложений ОС Windows. NetBIOS выполняет три основных функции:
1. определение имен NetBIOS;
2. служба дейтаграмм NetBIOS;
3. служба сеанса NetBIOS.
В таблице 3.3 приведено семейство протоколов TCP/IP.
Уровень транспорта Уровень транспорта TCP/IP отвечает за установления и поддержания соединения между двумя узлами.
Основные функции уровня:
1. подтверждение получения информации.
2. управление потоком данных;
3. упорядочение и ретрансляция пакетов.
4. В зависимости от типа службы могут быть использованы два протокола:
5. TCP (Transmission Control Protocol – протокол управления передачей);
6. UDP (User Datagram Protocol – пользовательский протокол дейтаграмм). TCP обычно используют в тех случаях, когда приложению требуется передать большой объем информации и убедиться, что данные своевременно получены адресатом. Приложения и службы, отправляющие небольшие объемы данных и не нуждающиеся в получении подтверждения, используют протокол UDP, который является протоколом без установления соединения.
Протокол управления передачей (TCP) Протокол TCP отвечает за надежную передачу данных от одного узла сети к другому. Он создает сеанс с установлением соединения, иначе говоря виртуальный канал между машинами.
Установление соединения происходит в три шага:
● Клиент, запрашивающий соединение, отправляет серверу пакет, указывающий номер порта, который клиент желает использовать, а также код (определенное число) ISN (Initial Sequence number).
● Сервер отвечает пакетом, содержащий ISN сервера, а также ISN клиента, увеличенный на 1.
● Клиент должен подтвердить установление соединения, вернув ISN сервера, увеличенный на 1.
Трехступенчатое открытие соединения устанавливает номер порта, а также ISN клиента и сервера. Каждый, отправляемый TCP – пакет содержит номера TCP – портов отправителя и получателя, номер фрагмента для сообщений, разбитых на меньшие части, а также контрольную сумму, позволяющую убедиться, что при передаче не произошло ошибок.
Пользовательский протокол дейтаграмм (UDP) В отличие от TCP UDP не устанавливает соединения. Протокол UDP предназначен для отправки небольших объемов данных без установки соединения и используется приложениями, которые не нуждаются в подтверждении адресатом их получения. UDP также использует номера портов для определения конкретного процесса по указанному IP адресу. Однако UDP порты отличаются от TCP портов и, следовательно, могут использовать те же номера портов, что и TCP, без конфликта между службами. Межсетевой уровень Межсетевой уровень отвечает за маршрутизацию данных внутри сети и между различными сетями. На этом уровне работают маршрутизаторы, которые зависят от используемого протокола и используются для отправки пакетов из одной сети (или ее сегмента) в другую (или другой сегмент сети). В стеке TCP/IP на этом уровне используется протокол IP. Протокол Интернета IP Протокол IP обеспечивает обмен дейтаграммами между узлами сети и является протоколом, не устанавливающим соединения и использующим дейтаграммы для отправки данных из одной сети в другую. Данный протокол не ожидает получение подтверждения (ASK, Acknowledgment) отправленных пакетов от узла адресата. Подтверждения, а также повторные отправки пакетов осуществляется протоколами и процессами, работающими на верхних уровнях модели.
К его функциям относится фрагментация дейтаграмм и межсетевая адресация. Протокол IP предоставляет управляющую информацию для сборки фрагментированных дейтаграмм. Главной функцией протокола является межсетевая и глобальная адресация. В зависимости от размера сети, по которой будет маршрутизироваться дейтаграмма или пакет, применяется одна из трех схем адресации.
Протоколы сопоставления адреса ARP и RARP. Для определения локального адреса по
IP-адресу используется протокол разрешения адреса Address Resolution Protocol
(ARP). ARP работает различным образом в зависимости от того, какой протокол
канального уровня работает в данной сети – протокол локальной сети (Ethernet,
Token Ring, FDDI) с возможностью широковещательного доступа одновременно ко
всем узлам сети, или же протокол глобальной сети (X.25, frame relay), как
правило, не поддерживающий широковещательный доступ. Существует также протокол,
решающий обратную задачу – нахождение IP-адреса по известному локальному
адресу. Он называется реверсивный ARP – RARP (Reverse Address Resolution
Protocol) и используется при старте бездисковых станций, не знающих в начальный
момент своего IP-адреса, но знающих адрес своего сетевого адаптера. В локальных
сетях ARP использует широковещательные кадры протокола канального уровня для
поиска в сети узла с заданным IP- адресом.
Узел, которому нужно выполнить отображение IP-адреса на локальный адрес, формирует ARP-запрос, вкладывает его в кадр протокола канального уровня, указывая в нем известный IP-адрес, и рассылает запрос широковещательно. Все узлы локальной сети получают ARP-запрос и сравнивают указанный там IP-адрес с собственным адресом. В случае их совпадения узел формирует ARP- ответ, в котором указывает свой IP-адрес и свой локальный адрес и отправляет его уже направленно, так как в ARP-запросе отправитель указывает свой локальный адрес. ARP-запросы и ответы используют один и тот же формат пакета. Протокол ICMP Протокол управления сообщениями Интернета (ICMP – Internet Control Message Protocol) используется IP и другими протоколами высокого уровня для отправки и получения отчетов о состоянии переданной информации. Этот протокол используется для контроля скорости передачи информации между двумя системами. Если маршрутизатор, соединяющий две системы, перегружен трафиком, он может отправить специальное сообщение ICMP – ошибку для уменьшения скорости отправления сообщений.
Протокол IGMP Узлы локальной сети используют протокол управления группами Интернета (IGMP – Internet Group Management Protocol), чтобы зарегистрировать себя в группе. Информация о группах содержится на маршрутизаторах локальной сети. Маршрутизаторы используют эту информацию для передачи групповых сообщений. Групповое сообщение, как и широковещательное, используется для отправки данных сразу нескольким узлам. NDIS Network Device Interface Specification – спецификация интерфейса сетевого устройства, программный интерфейс, обеспечивающий взаимодействие между драйверами транспортных протоколов, и соответствующими драйверами сетевых интерфейсов. Позволяет использовать несколько протоколов, даже если установлена только одна сетевая карта. Уровень сетевого интерфейса этот уровень модели TCP/IP отвечает за распределение IP- дейтаграмм. Он работает с ARP для определения информации, которая должна быть помещена в заголовок каждого кадра. Затем на этом уровне создается кадр, подходящий для используемого типа сети, такого как Ethernet, Token Ring или ATM, затем IP-дейтаграмма помещается в область данных этого кадра, и он отправляется в сеть.
Скачано с www.znanio.ru
© ООО «Знанио»
С вами с 2009 года.