Алгоритмы маршрутизации: различия между версиями
[непроверенная версия] | [непроверенная версия] |
KrBot (обсуждение | вклад) м подстановка даты в шаблон:Нет сносок |
|||
(не показано 38 промежуточных версий 33 участников) | |||
Строка 1: | Строка 1: | ||
{{rq|style|translate|wikify}} |
|||
'''Алгоритмы маршрутизации''' применяются для определения |
'''Алгоритмы маршрутизации''' применяются для определения наилучшего пути пакетов от источника к приёмнику и являются основой любого [[протокол маршрутизации|протокола маршрутизации]]. Для формулирования алгоритмов маршрутизации сеть рассматривается как граф. При этом маршрутизаторы являются узлами, а физические линии между маршрутизаторами — рёбрами соответствующего графа. Каждой грани графа присваивается определённое число — стоимость, зависящая от физической длины линии, скорости передачи данных по линии или стоимости линии. |
||
{{TOCright}} |
{{TOCright}} |
||
Строка 18: | Строка 19: | ||
== Типы алгоритмов == |
== Типы алгоритмов == |
||
=== Адаптивные алгоритмы === |
=== Адаптивные алгоритмы === |
||
==== Описание ==== |
==== Описание ==== |
||
принимают во внимание состояние линии |
принимают во внимание состояние линии |
||
==== Плюсы и минусы ==== |
==== Плюсы и минусы ==== |
||
+уменьшение среднего времени нахождения пакета в сети |
|||
+возможность динамической адаптации к состоянию сети<br /> |
+возможность динамической адаптации к состоянию сети<br /> |
||
-необходимо постоянно пересчитывать таблицы маршрутизации |
-необходимо постоянно пересчитывать таблицы маршрутизации |
||
=== Централизированные === |
|||
⚫ | |||
⚫ | |||
[[Алгоритмы маршрутизации#адаптивный централизированный алгоритм маршрутизации|адаптивный централизированный алгоритм]] |
|||
адаптивный централизированный алгоритм |
|||
==== Плюсы и минусы ==== |
|||
+RCC обладает всей информацией о состоянии сети, что позволяет принимать оптимальные решения< |
+RCC(Routing Control Center) обладает всей информацией о состоянии сети, что позволяет принимать оптимальные решения<br /> |
||
+узлы освобождены от подсчета таблиц маршрутизации< |
+узлы освобождены от подсчета таблиц маршрутизации<br /> |
||
-низкая надежность< |
-низкая надежность<br /> |
||
-узлы получают таблицы маршрутизации в различное время< |
-узлы получают таблицы маршрутизации в различное время<br /> |
||
-концентрация трафика возле RCC< |
-концентрация трафика возле RCC<br /> |
||
=== Изолированные === |
|||
==== Описание ==== |
|||
Узел извлекает информацию из полученных пакетов. |
Узел извлекает информацию из полученных пакетов. |
||
==== Плюсы и минусы ==== |
|||
+нет перегрузок<br /> |
+нет перегрузок<br /> |
||
-медленная адаптация к состоянию сети (время конвергенции) |
-медленная адаптация к состоянию сети (время конвергенции) |
||
<!-- |
<!-- |
||
==== Примеры ==== |
|||
Backward learning |
Backward learning |
||
а --> |
а --> |
||
=== Распределённые === |
|||
==== Описание ==== |
|||
[[дистанционно-векторный алгоритм маршрутизации|дистанционно-векторный алгоритм]], [[link state routing]] |
[[дистанционно-векторный алгоритм маршрутизации|дистанционно-векторный алгоритм]], [[link state routing]] |
||
==== Плюсы и минусы ==== |
|||
+лучшая адаптация< |
+лучшая адаптация<br /> |
||
-перегрузки |
-перегрузки |
||
=== Неадаптивные алгоритмы === |
=== Неадаптивные алгоритмы === |
||
==== Описание ==== |
==== Описание ==== |
||
не принимают во внимание текущее состояние сети, все маршруты рассчитываются до начала использования сети. Они в свою очередь подразделяются на алгоритмы, учитывающие топологию сети (spanning tree, flow based routing) и не учитывающие (flooding). |
не принимают во внимание текущее состояние сети, все маршруты рассчитываются до начала использования сети. Они в свою очередь подразделяются на алгоритмы, учитывающие топологию сети (spanning tree, flow based routing) и не учитывающие (flooding). |
||
Строка 73: | Строка 83: | ||
== Адаптивные алгоритмы == |
== Адаптивные алгоритмы == |
||
=== Централизированный === |
=== Централизированный === |
||
==== [[Адаптивный централизированный алгоритм]] ==== |
==== [[Адаптивный централизированный алгоритм]] ==== |
||
({{lang-en|adaptive centralized routing}}) |
({{lang-en|adaptive centralized routing}}) |
||
===== Описание ===== |
===== Описание ===== |
||
В сети существует так называемый центр маршрутизации (Routing Control Center, RCC), который получает информацию от всех узлов об их соседних узлах, длине очереди и загрузке линии. В функции RCC входит сбор информации, подсчет оптимальных маршрутов для каждого узла, составление таблиц маршрутизации и рассылка их узлам. |
В сети существует так называемый центр маршрутизации (Routing Control Center, RCC), который получает информацию от всех узлов об их соседних узлах, длине очереди и загрузке линии. В функции RCC входит сбор информации, подсчет оптимальных маршрутов для каждого узла, составление таблиц маршрутизации и рассылка их узлам. |
||
Строка 89: | Строка 102: | ||
=== Изолированный === |
=== Изолированный === |
||
==== Backward learning ==== |
==== Backward learning ==== |
||
===== Описание ===== |
===== Описание ===== |
||
Каждый узел берет только нужную информацию из полученных пакетов. Таким образом, каждый узел знает отправителя пакетов и количество [[хоп]]ов, которые этот пакет прошёл. Затем происходит сравнение с данными в таблице маршрутизации, и если у полученного пакета меньшее количество хопов, то происходит обновление таблицы. |
Каждый узел берет только нужную информацию из полученных пакетов. Таким образом, каждый узел знает отправителя пакетов и количество [[Транзитный участок|хоп]]ов, которые этот пакет прошёл. Затем происходит сравнение с данными в таблице маршрутизации, и если у полученного пакета меньшее количество хопов, то происходит обновление таблицы. |
||
===== Плюсы и минусы ===== |
===== Плюсы и минусы ===== |
||
Строка 98: | Строка 113: | ||
-не происходит обмен данными о маршрутизации между узлами |
-не происходит обмен данными о маршрутизации между узлами |
||
=== |
=== Распределённый === |
||
==== Дистанционно-векторный алгоритм ==== |
==== Дистанционно-векторный алгоритм ==== |
||
({{lang-en|distance vector routing}}) |
({{lang-en|distance vector routing}}) |
||
===== Описание ===== |
===== Описание ===== |
||
Также известен как Distributed Bellman-Ford Routing или Ford Fulkerson Algorithm. Данный алгоритм является |
Также известен как Distributed Bellman-Ford Routing или Ford Fulkerson Algorithm. Данный алгоритм является распределённым, итерационным и асинхронным. Его можно представить как: «расскажи своим соседям, как выглядит мир». Каждый узел ведёт таблицу маршрутизации с одной записью для каждого маршрутизатора подсети. Таблица представляет собой [[вектор]], содержащий 2 компонента: выбранную линию и дистанцию. Узел оценивает дистанцию (количество хопов, задержку или длину очереди) до каждого соседа и рассылает её своим соседям, которые в свою очередь выполняют то же самое. В результате полученной информации каждый узел заново подсчитывает таблицу маршрутизации. Применяется в протоколе маршрутизации [[RIP2|RIP]]. Впервые был применен в [[ARPANET]]. |
||
===== Алгоритм ===== |
===== Алгоритм ===== |
||
Предположим, что таблица только что была получена от соседа X, |
Предположим, что таблица только что была получена от соседа X, причём Xi является предположением X о том, сколько длится путь до маршрутизатора i. Если маршрутизатор знает, что передача данных до X длится m, то он знает так же, что он может достичь любой маршрутизатор і через X за X<sub>i</sub>+m. |
||
===== Плюсы и минусы ===== |
===== Плюсы и минусы ===== |
||
+самоорганизация<br /> |
+самоорганизация<br /> |
||
+относительно простая реализация<br /> |
+относительно простая реализация<br /> |
||
-плохая конвергенция ( |
-плохая конвергенция («сходимость»)<br /> |
||
-сложности при расширении сети |
-сложности при расширении сети |
||
===== Пример ===== |
===== Пример ===== |
||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
==== Маршрутизация по состоянию канала ==== |
==== Маршрутизация по состоянию канала ==== |
||
{{lang-en|Link state routing}} |
{{lang-en|Link state routing}} |
||
===== Описание ===== |
===== Описание ===== |
||
Алгоритм, относящийся к адаптивным алгоритмам и основанный на анализе состояния связей. Его можно представить как: «расскажи миру о том, кто твои соседи». Сначала узел знает только своих соседей и метрику связей, соединяющих его с ними. В процессе обмена информацией с соседними узлами узел получает информацию о топологии сети, при этом обменивается только |
Алгоритм, относящийся к адаптивным алгоритмам и основанный на анализе состояния связей. Его можно представить как: «расскажи миру о том, кто твои соседи». Сначала узел знает только своих соседей и метрику связей, соединяющих его с ними. В процессе обмена информацией с соседними узлами узел получает информацию о топологии сети, при этом обменивается только информацией о происшедших изменениях. В результате каждый узел знает всю топологию сети. Впервые был применен в [[ARPANET]] в 1979 году и пришёл на смену дистанционно-векторному алгоритму. Причинами перехода служили: |
||
* рост пропускной способности каналов и отсутствие её |
* рост пропускной способности каналов и отсутствие её учёта в дистанционно-векторном алгоритме |
||
* медленность дистанционно-векторного алгоритма, вызванная «счетом до бесконечности» |
* медленность дистанционно-векторного алгоритма, вызванная «счетом до бесконечности» |
||
Строка 135: | Строка 152: | ||
# подсчет маршрутов на основе полученной от других узлов информации |
# подсчет маршрутов на основе полученной от других узлов информации |
||
<!-- |
<!-- |
||
===== Плюсы и минусы ===== |
===== Плюсы и минусы ===== |
||
===== Пример ===== |
===== Пример ===== |
||
--> |
--> |
||
=== Широковещательная маршрутизация === |
=== Широковещательная маршрутизация === |
||
({{lang-en|broadcast routing}}) |
({{lang-en|broadcast routing}}) <br /><br /><br /> |
||
⚫ | |||
⚫ | |||
[[unicast]] — 1:1<br /> |
|||
[[ |
[[unicast]] — 1:1<br /> |
||
[[ |
[[multicast]] — 1:n<br /> |
||
[[broadcasting|broadcast]] — 1:* (1:all) |
|||
==== Простые методы ==== |
==== Простые методы ==== |
||
* индивидуальная отправка пакетов каждому получателю, что предъявляет определенные требования к сети, излишняя трата полосы пропускания, отправитель должен знать всех получателей |
* индивидуальная отправка пакетов каждому получателю, что предъявляет определенные требования к сети, излишняя трата полосы пропускания, отправитель должен знать всех получателей |
||
* flooding: слишком много повторяющихся пакетов |
* flooding: слишком много повторяющихся пакетов |
||
==== Multidestination Routing ==== |
==== Multidestination Routing ==== |
||
Каждый пакет содержит список всех целей. Каждый узел создает для каждого исходящего соединения копию пакета, которая содержит только адреса тех узлов, которые достижимы через это соединение. |
Каждый пакет содержит список всех целей. Каждый узел создает для каждого исходящего соединения копию пакета, которая содержит только адреса тех узлов, которые достижимы через это соединение. |
||
==== Многоадресная рассылка ==== |
==== Многоадресная рассылка ==== |
||
{{lang-en|multicast routing}} |
{{lang-en|multicast routing}} |
||
==== Алгоритм связующего дерева ==== |
==== Алгоритм связующего дерева ==== |
||
{{lang-en|spanning tree}} |
{{lang-en|spanning tree}} |
||
===== Описание ===== |
===== Описание ===== |
||
Связующее дерево (Spanning tree): граф, не содержащий петель. |
Связующее дерево (Spanning tree): граф, не содержащий петель. |
||
Строка 166: | Строка 185: | ||
==== Reverse path forwarding (Reverse path flooding) ==== |
==== Reverse path forwarding (Reverse path flooding) ==== |
||
Алгоритм является самым простым и неадаптивным вариантом. Каждый полученный пакет пересылается по всем линиям, за исключением той, через которую он был получен. При этом только отправитель должен знать все связующее дерево. |
Алгоритм является самым простым и неадаптивным вариантом. Каждый полученный пакет пересылается по всем линиям, за исключением той, через которую он был получен. При этом только отправитель должен знать все связующее дерево. |
||
Алгоритм: Каждый маршрутизатор знает путь, который он должен использовать для unicast-пакетов. При получении пакета проверяется, был ли пакет получен по линии, которая обычно используется |
Алгоритм: Каждый маршрутизатор знает путь, который он должен использовать для unicast-пакетов. При получении пакета проверяется, был ли пакет получен по линии, которая обычно используется для unicast-пакетов. Если да, то пакет пересылается по всем линиям, за исключением той, через которую он был получен. В противном случае пакет отбрасывается. |
||
==== Reverse path broadcast ==== |
==== Reverse path broadcast ==== |
||
Строка 172: | Строка 191: | ||
=== Shortest Path Routing === |
=== Shortest Path Routing === |
||
==== Описание ==== |
==== Описание ==== |
||
Данный алгоритм подсчитывает наименьший маршрут от корня дерева до узлов. Смысл заключается в создании пучка узлов Q, для которых уже был определен оптимальный маршрут. |
Данный алгоритм подсчитывает наименьший маршрут от корня дерева до узлов. Смысл заключается в создании пучка узлов Q, для которых уже был определен оптимальный маршрут. |
||
Строка 189: | Строка 209: | ||
== Неадаптивные == |
== Неадаптивные == |
||
=== Flow-Based Routing === |
=== Flow-Based Routing === |
||
==== Описание ==== |
==== Описание ==== |
||
Данный алгоритм является одним из неадаптивных алгоритмов. Он учитывает не только дистанцию между маршрутизаторами, но и загрузку сети. Полезен для нахождения маршрута для больших дистанций с большими задержками в доставке пакетов |
Данный алгоритм является одним из неадаптивных алгоритмов. Он учитывает не только дистанцию между маршрутизаторами, но и загрузку сети. Полезен для нахождения маршрута для больших дистанций с большими задержками в доставке пакетов |
||
<!-- ==== Алгоритм ==== |
<!-- ==== Алгоритм ==== |
||
==== Псевдокод ==== |
==== Псевдокод ==== |
||
==== Плюсы и минусы ==== --> |
==== Плюсы и минусы ==== --> |
||
==== Пример ==== |
==== Пример ==== |
||
Дан граф для capacity и матрица трафика |
Дан граф для capacity и матрица трафика |
||
: <center>[[ |
: <center>[[Файл:FBRExampleTopology.png|380px]][[Файл:512px-FBRExampleMatrix.jpg|380px]]</center> |
||
* Подсчет загрузки каждой линии |
* Подсчет загрузки каждой линии |
||
Строка 422: | Строка 446: | ||
=== Flooding (алгоритм «затопления») === |
=== Flooding (алгоритм «затопления») === |
||
==== Описание ==== |
|||
Является самым простым алгоритмом маршрутизации для распространения информации по сети. При получении пакета каждый узел пересылает его соседним узлам за исключением того, от которого пришёл пакет. |
Является самым простым алгоритмом маршрутизации для распространения информации по сети. При получении пакета каждый узел пересылает его соседним узлам за исключением того, от которого пришёл пакет. |
||
[[ |
[[Файл:Flooding routing.gif|thumb|Алгоритм «затопления»]] |
||
==== Эффективность ==== |
|||
Данный алгоритм обладает низкой эффективностью из-за повышенной загрузки сети. |
Данный алгоритм обладает низкой эффективностью из-за повышенной загрузки сети. |
||
⚫ | |||
<!-- ==== Пример ==== --> |
|||
--[[Special:Contributions/62.183.30.98|62.183.30.98]] 16:35, 27 декабря 2008 (UTC) |
|||
⚫ | |||
--[[Special:Contributions/62.183.30.98|62.183.30.98]] 16:35, 27 декабря 2008 (UTC) |
|||
⚫ | * Flooding with Acknowledge («затопление с подтверждениями»). Одной из проблем простого алгоритма «затопления» является то, что отправитель не знает о том, достиг ли пакет всех узлов сети. Каждый из узлов сети отправляет подтверждение о получении, если он получил подтверждение от всех узлов, которым он отправлял пакеты. |
||
⚫ | |||
⚫ | |||
==== Способы оптимизации ==== |
|||
⚫ | |||
===== [[Хоп|Hop counter]] ===== |
|||
⚫ | |||
===== Flooding with Acknowledge («затопление с подтверждениями») ===== |
|||
⚫ | |||
⚫ | |||
===== Unique resend ===== |
|||
⚫ | |||
== Другие алгоритмы == |
== Другие алгоритмы == |
||
=== Multipath Routing === |
=== Multipath Routing === |
||
==== Описание ==== |
==== Описание ==== |
||
Основная цель алгоритма |
Основная цель алгоритма — подсчёт альтернативных маршрутов и стоимости маршрутов. Стоимость — это вероятность использования альтернативного маршрута. В зависимости от этого каждый раз будет использоваться другой маршрут, что приведёт к уменьшению количества недоставленных пакетов. Использование этого метода делает компьютерную сеть очень надёжной. Метод чаще всего применяется для мобильных сетей, где состояние сети может часто изменяться и некоторые маршрутизаторы могут выходить из строя. |
||
<!-- |
|||
==== Алгоритм ==== |
|||
==== Псевдокод ==== |
|||
==== Плюсы и минусы ==== |
|||
==== Примеры ==== --> |
|||
=== Иерархическая маршрутизация === |
=== Иерархическая маршрутизация === |
||
Строка 455: | Строка 471: | ||
Одноуровневые или иерархические алгоритмы. Некоторые алгоритмы маршрутизации оперируют в одноуровневом пространстве, в то время как другие используют иерархию маршрутизации. В одноуровневой системе маршрутизации все маршрутизаторы равны по отношению друг к другу. В иерархической системе маршрутизации некоторые маршрутизаторы формируют то, что составляет основу (базу) маршрутизации. Например, те, которые находятся на высокоскоростных магистралях. Пакеты из небазовых маршрутизаторов перемещаются к базовым маршрутизаторам и перемещаются через них до тех пор, пока не достигнут общей области пункта назначения. Начиная с этого момента, они перемещаются от последнего базового маршрутизатора через один или несколько небазовых маршрутизаторов до конечного пункта назначения. |
Одноуровневые или иерархические алгоритмы. Некоторые алгоритмы маршрутизации оперируют в одноуровневом пространстве, в то время как другие используют иерархию маршрутизации. В одноуровневой системе маршрутизации все маршрутизаторы равны по отношению друг к другу. В иерархической системе маршрутизации некоторые маршрутизаторы формируют то, что составляет основу (базу) маршрутизации. Например, те, которые находятся на высокоскоростных магистралях. Пакеты из небазовых маршрутизаторов перемещаются к базовым маршрутизаторам и перемещаются через них до тех пор, пока не достигнут общей области пункта назначения. Начиная с этого момента, они перемещаются от последнего базового маршрутизатора через один или несколько небазовых маршрутизаторов до конечного пункта назначения. |
||
Системы маршрутизации часто устанавливают логические группы узлов, называемых доменами или областями. В иерархических системах одни маршрутизаторы какого-либо домена могут сообщаться с маршрутизаторами других доменов, в то время как другие маршрутизаторы этого домена могут поддерживать связь с маршрутизаторами только в пределах своего домена. В очень крупных сетях могут существовать дополнительные иерархические уровни. Маршрутизаторы наивысшего иерархического уровня образуют базу маршрутизации. |
Системы маршрутизации часто устанавливают логические группы узлов, называемых доменами или областями. В иерархических системах одни маршрутизаторы какого-либо домена могут сообщаться с маршрутизаторами других доменов, в то время как другие маршрутизаторы этого домена могут поддерживать связь с маршрутизаторами только в пределах своего домена. В очень крупных сетях могут существовать дополнительные иерархические уровни. Маршрутизаторы наивысшего иерархического уровня образуют базу маршрутизации. |
||
Основным преимуществом иерархической маршрутизации является то, что она имитирует организацию большинства компаний и, следовательно, очень хорошо |
Основным преимуществом иерархической маршрутизации является то, что она имитирует организацию большинства компаний и, следовательно, очень хорошо поддерживает их схемы трафика. Большая часть сетевого трафика компании сосредоточена в пределах своего домена, следовательно, внутридоменным маршрутизаторам необходимо иметь информацию только о других маршрутизаторах в пределах своего домена, поэтому их алгоритмы маршрутизации могут быть упрощенными. Соответственно, может быть уменьшен и трафик обновления маршрутизации, зависящий от используемого алгоритма маршрутизации. |
||
<!-- |
|||
=== Routing with Mobility === |
|||
--> |
|||
== Литература == |
== Литература == |
||
* {{книга |
* {{книга |
||
Строка 474: | Строка 488: | ||
|автор = Andrew S. Tanenbaum |
|автор = Andrew S. Tanenbaum |
||
|заглавие = COMPUTER NETWORKS |
|заглавие = COMPUTER NETWORKS |
||
| |
|издательство = Personal Education |
||
|год = 2002 |
|год = 2002 |
||
}} |
}} |
||
{{Нет сносок|дата=2013-01-27}} |
|||
{{compu-net-stub}} |
|||
[[Категория:Алгоритмы маршрутизации]] |
[[Категория:Алгоритмы маршрутизации]] |
||
[[en:Routing algorithm]] |
Текущая версия от 23:02, 17 апреля 2023
Для улучшения этой статьи желательно:
|
Алгоритмы маршрутизации применяются для определения наилучшего пути пакетов от источника к приёмнику и являются основой любого протокола маршрутизации. Для формулирования алгоритмов маршрутизации сеть рассматривается как граф. При этом маршрутизаторы являются узлами, а физические линии между маршрутизаторами — рёбрами соответствующего графа. Каждой грани графа присваивается определённое число — стоимость, зависящая от физической длины линии, скорости передачи данных по линии или стоимости линии.
Классификация
[править | править код]Алгоритмы маршрутизации можно разделить на:
- адаптивные и неадаптивные
- глобальные и децентрализованные
- статические и динамические
Требования
[править | править код]- точность
- простота
- надёжность
- стабильность
- справедливость
- оптимальность
Типы алгоритмов
[править | править код]Адаптивные алгоритмы
[править | править код]Описание
[править | править код]принимают во внимание состояние линии
Плюсы и минусы
[править | править код]+уменьшение среднего времени нахождения пакета в сети
+возможность динамической адаптации к состоянию сети
-необходимо постоянно пересчитывать таблицы маршрутизации
Централизированные
[править | править код]Описание
[править | править код]адаптивный централизированный алгоритм
Плюсы и минусы
[править | править код]+RCC(Routing Control Center) обладает всей информацией о состоянии сети, что позволяет принимать оптимальные решения
+узлы освобождены от подсчета таблиц маршрутизации
-низкая надежность
-узлы получают таблицы маршрутизации в различное время
-концентрация трафика возле RCC
Изолированные
[править | править код]Описание
[править | править код]Узел извлекает информацию из полученных пакетов.
Плюсы и минусы
[править | править код]+нет перегрузок
-медленная адаптация к состоянию сети (время конвергенции)
Распределённые
[править | править код]Описание
[править | править код]дистанционно-векторный алгоритм, link state routing
Плюсы и минусы
[править | править код]+лучшая адаптация
-перегрузки
Неадаптивные алгоритмы
[править | править код]Описание
[править | править код]не принимают во внимание текущее состояние сети, все маршруты рассчитываются до начала использования сети. Они в свою очередь подразделяются на алгоритмы, учитывающие топологию сети (spanning tree, flow based routing) и не учитывающие (flooding).
Плюсы и минусы
[править | править код]+простота
+хорошие результаты при неизменной топологии и нагрузке
-невозможность реагирования на изменения
-низкая скорость в неоднородных сетях
Примеры
[править | править код]- Shortest Path
- Flow based
- Flooding
Адаптивные алгоритмы
[править | править код]Централизированный
[править | править код](англ. adaptive centralized routing)
Описание
[править | править код]В сети существует так называемый центр маршрутизации (Routing Control Center, RCC), который получает информацию от всех узлов об их соседних узлах, длине очереди и загрузке линии. В функции RCC входит сбор информации, подсчет оптимальных маршрутов для каждого узла, составление таблиц маршрутизации и рассылка их узлам.
Плюсы и минусы
[править | править код]+RCC обладает всей информацией и может создавать «идеальные» маршруты
+узлы освобождены от необходимости расчета таблиц маршрутизации
-низкая надежность
-время от времени требуется перерасчет таблиц маршрутизации
-некорректная работа при разделенных сетях
-IS получают информации в различное время
-концентрация трафика возле RCC
Изолированный
[править | править код]Backward learning
[править | править код]Описание
[править | править код]Каждый узел берет только нужную информацию из полученных пакетов. Таким образом, каждый узел знает отправителя пакетов и количество хопов, которые этот пакет прошёл. Затем происходит сравнение с данными в таблице маршрутизации, и если у полученного пакета меньшее количество хопов, то происходит обновление таблицы.
Плюсы и минусы
[править | править код]+легкость реализации
-проблемы при изменении топологии и нагрузки
-не происходит обмен данными о маршрутизации между узлами
Распределённый
[править | править код]Дистанционно-векторный алгоритм
[править | править код](англ. distance vector routing)
Описание
[править | править код]Также известен как Distributed Bellman-Ford Routing или Ford Fulkerson Algorithm. Данный алгоритм является распределённым, итерационным и асинхронным. Его можно представить как: «расскажи своим соседям, как выглядит мир». Каждый узел ведёт таблицу маршрутизации с одной записью для каждого маршрутизатора подсети. Таблица представляет собой вектор, содержащий 2 компонента: выбранную линию и дистанцию. Узел оценивает дистанцию (количество хопов, задержку или длину очереди) до каждого соседа и рассылает её своим соседям, которые в свою очередь выполняют то же самое. В результате полученной информации каждый узел заново подсчитывает таблицу маршрутизации. Применяется в протоколе маршрутизации RIP. Впервые был применен в ARPANET.
Алгоритм
[править | править код]Предположим, что таблица только что была получена от соседа X, причём Xi является предположением X о том, сколько длится путь до маршрутизатора i. Если маршрутизатор знает, что передача данных до X длится m, то он знает так же, что он может достичь любой маршрутизатор і через X за Xi+m.
Плюсы и минусы
[править | править код]+самоорганизация
+относительно простая реализация
-плохая конвергенция («сходимость»)
-сложности при расширении сети
Пример
[править | править код]При использовании алгоритма возникают проблемы при отключении одного из узлов от сети — проблема «Count to Infinity» (счет до бесконечности).
Предотвращение: Split Horizont Algorithm — «не говори мне то, что я сказал тебе»
Маршрутизация по состоянию канала
[править | править код]англ. Link state routing
Описание
[править | править код]Алгоритм, относящийся к адаптивным алгоритмам и основанный на анализе состояния связей. Его можно представить как: «расскажи миру о том, кто твои соседи». Сначала узел знает только своих соседей и метрику связей, соединяющих его с ними. В процессе обмена информацией с соседними узлами узел получает информацию о топологии сети, при этом обменивается только информацией о происшедших изменениях. В результате каждый узел знает всю топологию сети. Впервые был применен в ARPANET в 1979 году и пришёл на смену дистанционно-векторному алгоритму. Причинами перехода служили:
- рост пропускной способности каналов и отсутствие её учёта в дистанционно-векторном алгоритме
- медленность дистанционно-векторного алгоритма, вызванная «счетом до бесконечности»
Алгоритм
[править | править код]- определение адресов соседних узлов: новые узлы рассылают приветствие (HELLO-сообщения), соседние узлы сообщают свои адреса
- происходит при помощи рассылки HELLO-запросов
- измерение метрики линий или времени передачи данных до соседних узлов
- происходит в результате рассылки эхо-сообщений
- организация собранных данных в пакет, содержащий личный адрес, порядковый номер (для избежания повторений), возраст (для отброса устаревшей информации), дистанцию
- рассылка пакетов всем узлам сети (flooding)
- подсчет маршрутов на основе полученной от других узлов информации
Широковещательная маршрутизация
[править | править код](англ. broadcast routing)
Терминология
[править | править код]unicast — 1:1
multicast — 1:n
broadcast — 1:* (1:all)
Простые методы
[править | править код]- индивидуальная отправка пакетов каждому получателю, что предъявляет определенные требования к сети, излишняя трата полосы пропускания, отправитель должен знать всех получателей
- flooding: слишком много повторяющихся пакетов
Multidestination Routing
[править | править код]Каждый пакет содержит список всех целей. Каждый узел создает для каждого исходящего соединения копию пакета, которая содержит только адреса тех узлов, которые достижимы через это соединение.
Многоадресная рассылка
[править | править код]англ. multicast routing
Алгоритм связующего дерева
[править | править код]англ. spanning tree
Описание
[править | править код]Связующее дерево (Spanning tree): граф, не содержащий петель. Связующее дерево известно всем узлам. В соответствии с этим каждый узел рассылает копии пакетов
Reverse path forwarding (Reverse path flooding)
[править | править код]Алгоритм является самым простым и неадаптивным вариантом. Каждый полученный пакет пересылается по всем линиям, за исключением той, через которую он был получен. При этом только отправитель должен знать все связующее дерево. Алгоритм: Каждый маршрутизатор знает путь, который он должен использовать для unicast-пакетов. При получении пакета проверяется, был ли пакет получен по линии, которая обычно используется для unicast-пакетов. Если да, то пакет пересылается по всем линиям, за исключением той, через которую он был получен. В противном случае пакет отбрасывается.
Reverse path broadcast
[править | править код]В отличие от Reverse path forwarding пакеты отправляются только по линиям, по которым другие узлы принимают данные
Shortest Path Routing
[править | править код]Описание
[править | править код]Данный алгоритм подсчитывает наименьший маршрут от корня дерева до узлов. Смысл заключается в создании пучка узлов Q, для которых уже был определен оптимальный маршрут. Оператор генерирует таблицы маршрутизации, которые загружаются при его инициализации и более не изменяются. Основывается на алгоритме Дейкстры.
Алгоритм
[править | править код]Наименьшее расстояние от A до D
- узел A помечается как рассматриваемый
- присвоить всем соседним узлам значение с дистанцией до рассматриваемого узла B(2,A), G(6,A) и добавить их в список кандидатов
- выбрать из списка кандидатов узел с наименьшей дистанцией B(2,A)
- пометить этот узел как рассматриваемый и добавить его в дерево
- перейти к пункту 2
Плюсы и минусы
[править | править код]+простота
+хорошие результаты при постоянной топологии сети и нагрузке
Неадаптивные
[править | править код]Flow-Based Routing
[править | править код]Описание
[править | править код]Данный алгоритм является одним из неадаптивных алгоритмов. Он учитывает не только дистанцию между маршрутизаторами, но и загрузку сети. Полезен для нахождения маршрута для больших дистанций с большими задержками в доставке пакетов
Пример
[править | править код]Дан граф для capacity и матрица трафика
- Подсчет загрузки каждой линии
- взять одно из ребер графа
- найти, где оно встречается в таблице
- сложить все скорости из таблицы для этого ребра
Line | λi (packts/sec) |
---|---|
AB | 3(AB) + 7(ABC) + 7(BAD) + 4(BAF) + 3(BADG) =24 |
AD | 4(AD) + 2(ADE) + 2(ADG) + 5(ADEH) + 7(BAD) + 3(BADG) = 23 |
AF | 5(AF) + 4(BAF) = 9 |
BC | 7(ABC) + 3(BC) + 4(BCH) = 14 |
BE | 3(BE) = 3 |
CE | 7(CED) + 5(CE) + 3(CEDF) = 15 |
CH | 4(BCH) + 5(CHG) + 3(CH) = 12 |
DE | 2(ADE) + 5(ADEH) + 7(CED) + 3(CEDF) + 2(DE)+ 9(DEH) + 3(EDF)+ 9(FDEH) = 40 |
DF | 3(CEDF)+ 9(DF) + 3(EDF)+ 9(FDEH) = 24 |
EH | 5(ADEH)+ 9(DEH)+ 1(EHG)+ 2(EH) + 9(FDEH) = 26 |
FG | 1(FG) = 1 |
GH | 1(GH) + 1(EHG) + 5(CHG) = 7 |
DG | 2(ADG) + 3(BADG) + 2(DG) = 7 |
- подсчет задержки для каждого графа по формуле Ti = 1/(μCi-λi).
Line | λi (packts/sec) | μCi (packts/sec) | Ti (msec) |
---|---|---|---|
AB | 24 | 50 | 38.46 |
AD | 23 | 50 | 37.04 |
AF | 9 | 37.5 | 35.09 |
BC | 14 | 25 | 90.91 |
BE | 3 | 50 | 21.28 |
CE | 15 | 75 | 16.67 |
CH | 12 | 50 | 26.32 |
DE | 40 | 50 | 100 |
DF | 24 | 25 | 1000 |
EH | 26 | 50 | 41.67 |
FG | 1 | 100 | 10.1 |
GH | 7 | 62.5 | 18.02 |
DG | 7 | 62.5 | 18.02 |
- Подсчет стоимости каждого ребра по формуле: Wi = λi/∑λi.
Line | λi (packts/sec) | μCi (packts/sec) | Ti (msec) | Wi |
---|---|---|---|---|
AB | 24 | 50 | 38.46 | 0.117 |
AD | 23 | 50 | 37.04 | 0.112 |
AF | 9 | 37.5 | 35.09 | 0.044 |
BC | 14 | 25 | 90.91 | 0.068 |
BE | 3 | 50 | 21.28 | 0.015 |
CE | 15 | 75 | 16.67 | 0.073 |
CH | 12 | 50 | 26.32 | 0.059 |
DE | 40 | 50 | 100 | 0.195 |
DF | 24 | 25 | 1000 | 0.117 |
EH | 26 | 50 | 41.67 | 0.127 |
FG | 1 | 100 | 10.1 | 0.005 |
GH | 7 | 62.5 | 18.02 | 0.034 |
DG | 7 | 62.5 | 18.02 | 0.034 |
- подсчет общей задержки Toverall = ∑Ti•Wi Получаем: Toverall=162.531msec.
Так как полученное значение слишком велико, то его можно уменьшить за счет замены пути с самой большой задержкой DF(Ti, max = 1000msec) на путь D->G->F
Flooding (алгоритм «затопления»)
[править | править код]Является самым простым алгоритмом маршрутизации для распространения информации по сети. При получении пакета каждый узел пересылает его соседним узлам за исключением того, от которого пришёл пакет.
Данный алгоритм обладает низкой эффективностью из-за повышенной загрузки сети.
Для улучшения эффективности алгоритма используются следующие способы:
- Hop counter. В этом случае к каждому пакету прибавляется счетчик хопов. Отправитель устанавливает этот счетчик и каждый узел сети, который его пересылает, уменьшает этот счетчик на 1.
- Flooding with Acknowledge («затопление с подтверждениями»). Одной из проблем простого алгоритма «затопления» является то, что отправитель не знает о том, достиг ли пакет всех узлов сети. Каждый из узлов сети отправляет подтверждение о получении, если он получил подтверждение от всех узлов, которым он отправлял пакеты.
- Unique resend. Каждая станция запоминает пересланные пакеты и не посылает их ещё раз. Данный метод оптимизации очень продуктивен в сетях с топологией, отличной от дерева
Другие алгоритмы
[править | править код]Multipath Routing
[править | править код]Описание
[править | править код]Основная цель алгоритма — подсчёт альтернативных маршрутов и стоимости маршрутов. Стоимость — это вероятность использования альтернативного маршрута. В зависимости от этого каждый раз будет использоваться другой маршрут, что приведёт к уменьшению количества недоставленных пакетов. Использование этого метода делает компьютерную сеть очень надёжной. Метод чаще всего применяется для мобильных сетей, где состояние сети может часто изменяться и некоторые маршрутизаторы могут выходить из строя.
Иерархическая маршрутизация
[править | править код]англ. Hierarchical Routing Одноуровневые или иерархические алгоритмы. Некоторые алгоритмы маршрутизации оперируют в одноуровневом пространстве, в то время как другие используют иерархию маршрутизации. В одноуровневой системе маршрутизации все маршрутизаторы равны по отношению друг к другу. В иерархической системе маршрутизации некоторые маршрутизаторы формируют то, что составляет основу (базу) маршрутизации. Например, те, которые находятся на высокоскоростных магистралях. Пакеты из небазовых маршрутизаторов перемещаются к базовым маршрутизаторам и перемещаются через них до тех пор, пока не достигнут общей области пункта назначения. Начиная с этого момента, они перемещаются от последнего базового маршрутизатора через один или несколько небазовых маршрутизаторов до конечного пункта назначения. Системы маршрутизации часто устанавливают логические группы узлов, называемых доменами или областями. В иерархических системах одни маршрутизаторы какого-либо домена могут сообщаться с маршрутизаторами других доменов, в то время как другие маршрутизаторы этого домена могут поддерживать связь с маршрутизаторами только в пределах своего домена. В очень крупных сетях могут существовать дополнительные иерархические уровни. Маршрутизаторы наивысшего иерархического уровня образуют базу маршрутизации. Основным преимуществом иерархической маршрутизации является то, что она имитирует организацию большинства компаний и, следовательно, очень хорошо поддерживает их схемы трафика. Большая часть сетевого трафика компании сосредоточена в пределах своего домена, следовательно, внутридоменным маршрутизаторам необходимо иметь информацию только о других маршрутизаторах в пределах своего домена, поэтому их алгоритмы маршрутизации могут быть упрощенными. Соответственно, может быть уменьшен и трафик обновления маршрутизации, зависящий от используемого алгоритма маршрутизации.
Литература
[править | править код]- Cisco Systems. Руководство Cisco по междоменной многоадресатной маршрутизации = Interdomain Multicast Solutions Guide. — М.: «Вильямс», 2004. — С. 320. — ISBN 5-8459-0605-9.
- Andrew S. Tanenbaum. COMPUTER NETWORKS. — Personal Education, 2002.
В статье есть список источников, но не хватает сносок. |