- •Протоколы локальных сетей
- •Введение
- •Протокол
- •Существует два основных метода взаимодействия абонентов в сети:
- •Метод дейтаграмм
- •Пакет при этом методе передается без установления логического канала, то есть без предварительного
- •Метод дейтаграмм предъявляет повышенные требования к аппаратуре (так как приемник всегда должен быть
- •Метод с логическим соединением
- •При этом методе пакет передается только после того, как будет установлено логическое соединение
- •Метод с логическим соединением более сложен, чем метод дейтаграмм, но гораздо надежнее, поскольку
- •Примеры протоколов, работающих по методу дейтаграмм — это протоколы IP и IPX.
- •Именно для того, чтобы объединить достоинства обоих методов, эти протоколы используются в виде
- •Схема соответствия протоколов Novell и 7-уровневой модели OSI
- •Сетевому уровню модели OSI соответствует протокол IPX.
- •Протокол IPX
- •Общие сведения
- •В качестве прототипа протокола IPX компания Novell использовала один из первых протоколов локальных
- •Если устройство, с которым необходимо установить связь, находится в другой сети, IPX прокладывает
- •Формат пакета IPX
- •Все поля, кроме поля Data, образуют заголовок пакета.
- •Контрольная сумма (Checksum)
- •Общая длина пакета (Length)
- •Управление транспортом (Transport control)
- •Тип пакета (Packet type)
- •Номер сети получателя
- •Адрес станции-получателя (DestNode)
- •Гнездо программы-
- •Номер сети отправителя пакета (SourceNetwork),
- •Передаваемые данные (Data)
- •Пример структуры заголовка
- •Работа с драйвером IPX/SPX
- •API драйвера протокола IPX состоит из примерно дюжины функций, предназначенных для выполнения операций
- •Процедура приема/передачи
- •Прикладные программы не работают напрямую с драйвером сетевого адаптера. Запросы на прием и
- •Если на рабочей станции используется операционная система MS-DOS, функции, необходимые для реализации протокола
- •Для приема или передачи пакета прикладная программа должна подготовить пакет данных, сформировав его
- •Подготовив блок ECB, прикладная программа передает его адрес соответствующей функции IPX для выполнения
- •Функции IPX, принимающие или передающие пакет, не выполняют ожидания завершения операции, а сразу
- •Есть и другая возможность. В блоке ECB можно указать адрес процедуры, которая будет
- •Формат блока ECB
- •Блок ECB состоит из фиксированной части размером 36 байт и массива дескрипторов, описывающих
- •Поле Link
- •Поле ESRAddress
- •Поле InUse
- •FFh - ECB используется для передачи пакета данных;
- •Программа может постоянно опрашивать поле InUse, ожидая завершения процесса передачи или приема данных.
- •Поле CCode
- •Если с данным ECB была связана команда приема пакета, в поле CCode могут
- •Если ECB использовался для передачи пакета, в поле CCode после завершения передачи могут
- •Обратим еще раз ваше внимание на то, что, даже если код завершения в
- •Одна из интересных особенностей при передаче пакетов заключается в том, что вы можете
- •Поле Socket
- •Поле IPXWorkspace
- •Поле DriverWorkspace
- •Поле ImmAddress
- •Поле FragmentCnt
- •Значение, записанное в поле FragmentCnt, не должно быть равно нулю. Если в этом
- •Сразу вслед за полем FragmentCnt располагаются дескрипторы фрагментов, состоящие из указателя в формате
- •Самый первый фрагмент не должен быть короче 30 байт, так как там должен
- •Подведём итоги по первой части
- •Недостатки IPX
- •Большие накладные расходы на служебную информацию. Сравнительно небольшая максимальная длина поля данных IPX-пакета
- •Дополнительный трафик, возникающий из-за того, что активные рабочие станции используют часто генерируемые широковещательные
- •Протокол SPX
- •Общие сведения
- •Преимущества использования SPX
- •Формат пакета SPX
- •Отличия форматов IPX и SPX
- •Управление потоком данных (ConnControl)
- •Биты
- •40h Acknowledgement Required. Бит используется драйвером SPX. Вам не следует модифицировать его значение
- •Тип данных в пакете (DataStreamType)
- •Биты
- •FFh End-of-Connection- Acknowledgement. Это значение отмечает пакет, подтверждающий завершение связи. Такой пакет является
- •Идентификатор канала отправителя (SourceConnID)
- •Идентификатор канала получателя (DestConnID)
- •Счетчик переданных пакетов (SeqNumber)
- •Номер следующего пакета (AckNumber)
- •Количество буферов для приема
- •Для протокола используется точно такой же блок ECB, что и для протокола IPX.
- •Протокол SPX позволяет осуществить от 100 до 2000 соединений одновременно (по умолчанию это
- •На основе протокола SPX работают утилита удаленной консоли и службы печати фирмы Novell.
- •Подведём итоги по второй части
- •Взаимодействие уровней стека IPX/SPX
- •Протокол SAP (Service Advertising Protocol) выполняет вспомогательную роль. С помощью протокола SAP каждый
- •В стеке Novell прикладные протоколы NCP и SAP взаимодействует с сетевым уровнем непосредственно,
- •Подведем общий итог
- •Протоколы стека IPX/SPX до недавнего времени хорошо работали в локальных сетях и не
- •Протоколы IPX/SPX широко используются в серверах NetWare до 4-й версии включительно. Начиная с
- •Прикладные программы могут обращаться непосредственно к уровню IPX, например, для посылки широковещательных сообщений,
Обратим еще раз ваше внимание на то, что, даже если код завершения в поле CCode равен нулю, это не гарантирует успешной доставки пакета адресату.
Из-за чего пакет может не дойти до адресата? Во-первых, пакет может быть потерян в процессе передачи по кабелю. Во-вторых, станция, адрес которой указан в заголовке пакета, может не работать или такой станции может вообще не быть в указанной сети. В-третьих, станция-адресат может не ожидать пакет на указанном сокете.
Одна из интересных особенностей при передаче пакетов заключается в том, что вы можете передавать пакеты "сами себе", т. е. передающая и принимающая программы могут работать на одной и той же станции и использовать один и тот же сокет.
Поле Socket
Cодержит номер гнезда, связанный с данным ECB. Если ECB используется для приема, это поле содержит номер гнезда, на котором выполняется прием пакета. Если же ECB используется для передачи, это поле содержит номер гнезда передающей программы. Заполняется в прикладной программе и используется протоколом IPX для заполнения поля SourceSocket пакета IPX.
Поле IPXWorkspace
Зарезервировано для использования драйвером IPX.
Поле DriverWorkspace
Зарезервировано для использования драйвером сетевого адаптера.
Поле ImmAddress
Поле ImmAddress (Immediate Address - непосредственный адрес) содержит адрес узла в сети, в который будет направлен пакет. Если пакет передается в пределах одной сети, поле ImmAddress будет содержать адрес станции- получателя (такой же, как и в заголовке пакета IPX). Если же пакет предназначен для другой сети и будет проходить через мост, поле ImmAddress будет содержать адрес этого моста в сети, из которой передается пакет.
Поле FragmentCnt
Устанавливается прикладной программой и содержит количество фрагментов, на которые надо разбить принятый пакет или из которых надо собрать передаваемый пакет, т.е. в программе можно указать отдельные буферы для приема/передачи заголовка и данных пакета. В этом случае значение поля FragmentCnt должно быть равно 2.
Значение, записанное в поле FragmentCnt, не должно быть равно нулю. Если в этом поле записано значение 1, весь пакет вместе с заголовком записывается в один общий буфер.
Сразу вслед за полем FragmentCnt располагаются дескрипторы фрагментов, состоящие из указателя в формате [сегмент:смещение] на фрагмент Address и поля размера фрагмента Size.
Если программе надо разбить принятый пакет на несколько частей, она должна установить в поле FragmentCnt значение, равное количеству требуемых фрагментов. Затем для каждого фрагмента необходимо создать дескриптор, в котором указать адрес буфера и размер фрагмента. Аналогичные действия выполняются и при сборке пакета перед передачей из нескольких фрагментов.
Самый первый фрагмент не должен быть короче 30 байт, так как там должен поместиться заголовок пакета IPX.