Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
ССиСК для ИЭФ.doc
Скачиваний:
34
Добавлен:
01.09.2019
Размер:
1.07 Mб
Скачать

11.10.2. Протокольные блоки данных моста (bpdu – Bridge Protocol Data Unit). Инициализация топологии

Для автоматического определения начальной активной конфигурации дерева все мосты сети после их инициализации начинают периодически обмениваться специальными пакетами, называемыми протокольными блоками данных моста – BPDU (Bridge Protocol Data Unit).

Пакеты BPDU (рис.11.14) помещаются в поле данных кадров канального уровня, например, кадров Ethernet. Все мосты должны поддерживать общий групповой адрес, с помощью которого кадры, содержащие пакеты BPDU, передаются одновременно всем мостам сети.

Рис. 11.14. Протокольные блоки данных моста – BPDU

  • Поля выделенные зеленым цветом используются для выбора корневого моста и решения- работать порту или быть заблокированным.

  • Поле Hello Time (время посылки пакетов BPDU ) – интервал, через который посылаются BPDU.

  • Поле Max Age (Максимальное время устаревания) – интервал, через который данные из предыдущего BPDU считаются недействительными.

  • Поле Forward Delay (задержка перехода) – время перехода портов коммутатора в очередное (возможно, активное) состояние. Такая задержка необходима, чтобы исключить возможность временного возникновения альтернативных маршрутов при неодновременной смене состояний портов во время конфигурации.

У пакета BPDU уведомления о реконфигурации отсутствуют все поля, кроме двух первых.

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

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

  1. RID (Root IDentifier) – идентификатор корневого моста, в начальный момент работы алгоритма STA каждый мост присваивает этой переменной свой собственный идентификатор.

  2. min RPC (min Root Path Cost) – наименьшее значение расстояния до корня, встретившееся в пакетах BPDU, принятых от корневого моста по i-му порту. Для каждого порта моста имеется своя переменная min RPC, начальное значение этой переменной равно максимально допустимому значению расстояния, определяемому форматом переменной.

  3. min BID и min PID – идентификаторы моста и порта, от которого поступил пакет, на основании которого присвоено значение расстояния до корня переменной min RPC – по две переменные на каждый порт.

Мост обрабатывает поступающие на порты сообщения BPDU следующим образом:

  • Сначала мост сравнивает значение идентификатора корневого моста из BPDU с текущим значением переменной RI.

  • Если это значение больше текущего значения RID, то принятый пакет просто уничтожается, так как он не несет никакой информации о расстоянии до корневого моста – он пришел от моста, который не является корневым.

  • Если оно равно текущему значению RID, то значит принят пакет от уже известного корня. Находящееся в пакете расстояние до корня сравнивается с найденным ранее минимальным расстоянием min RPC, и если новое значение меньше, то оно переписывается в переменную min RPC данного порта. Затем мост наращивает значение поля расстояния до корня на величину условной стоимости сегмента, по которому пришел пакет, помещает в поле идентификатора моста свой идентификатор и передает этот пакет на все свои порты, кроме того порта, от которого получен пакет. В переменные min BID и min PID записываются идентификаторы моста, от которого получен пакет BPDU, и его порта.

  • Если же значение идентификатора корневого моста у принятого BPDU меньше текущего, то это значит, что обнаружен мост, у которого больше прав претендовать на звание корневого. Его идентификатор фиксируется в переменной RID, а все значения переменных min RPC устанавливаются в исходное значение, так как они были вычислены ранее на основании расстояний до моста, на самом деле корнем не являющегося. Затем пакет BPDU обрабатывается точно по тому же алгоритму, что и в предыдущем случае.

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

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

Мосты, знающие, что они не корневые, определяют свой корневой порт как порт, имеющий минимальное расстояние до корневого моста. Для этого для каждого порта вычисляется расстояние RPC как сумма переменной min RPC и условной стоимости сегмента, с которым связан данный порт, так как в переменной min RPC это время учтено не было. Затем выбирается корневой порт, как порт с минимальным значением RPC. После этого данное значение называется расстоянием до корня данного моста – RPC.

Затем мост проверяет все оставшиеся порты как претендентов на звание назначенных портов сегментов, к которым они подключены. Он сравнивает значение min RPC данного порта со значением RPC, то есть сравнивает расстояния до корня от других мостов данного сегмента со своим собственным. Если его собственное расстояние оказывается меньше по каждому порту, то он фиксируется как назначенный. Если же оно больше, то порт переводится в заблокированное состояние, в котором он не будет ни принимать, ни передавать информационные пакеты в рабочем режиме, после установления активной конфигурации. Если же расстояния оказываются равными, то мост сравнивает сначала свой идентификатор с идентификатором min BID моста-конкурента, а если и они равны (то есть конкурируют его собственные порты), то сравниваются в конце концов идентификаторы портов.

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

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]