Команды route: Как прописать статический маршрут? И зачем он нужен? | Info-Comp.ru
Содержание
Настройка сетевой маршрутизации Linux – команда route
Для определения и задания маршрутов в сетях существуют динамическая и статическая маршрутизации. В первом случае маршруты задаются специальным демоном маршрутизации, который модифицирует соответствующим образом таблицу маршрутизации ядра. Во втором случае маршруты задаются администратором/пользователем при помощи команды route. Маршруты, заданные командой route не изменяются, даже если включена динамическая маршрутизация.
Содержание
- Как работает маршрутизация?
- Синтаксис и основные опции
- Примеры использования
Как работает маршрутизация?
Прежде всего нужно понимать, что процессы маршрутизации осуществляются на сетевом уровне. Для каждого пакета проводится сравнение его целевого IP-адреса с записями в таблице маршрутизации. Когда обнаруживается хотя бы частичное соответствие с одним из шлюзов в таблице, пакет направляется к следующему узлу (шлюзу), соответствующему найденному маршруту. И здесь может возникать несколько ситуаций:
Первая — когда, например, пакет адресуется компьютеру, находящемуся в той же сети, что и источник пакета, а точнее сказать — его отправитель. В данной ситуации для такого пакета следующим шлюзом является один из локальных интерфейсов и он (пакет) отправляется сразу к адресату. Такие «явные» и «короткие» шлюзы обычно задаются во время конфигурирования сетевых интерфейсов — командой ifconfig.
Вторая — когда адрес назначения пакта не соответствует ни одному шлюзу в таблице маршрутизации. В таком случае, во избежание коллизий в сети и её чрезмерной нагрузки должен быть задействован шлюз по-умолчанию. Другими словами, это такой маршрут, который указывает системному ядру: все остальные пакеты (без соответствий в таблице маршрутов) направляй сюда. Если шлюз по-умолчанию не будет предусмотрен, то отправляющей стороне посылается сообщение о недостижимости сети или узла.
Как правило, локальные сети имеют единственный шлюз во внешнюю среду, например в Интернет. В свою очередь, в сети Интернет таких «стандартных маршрутов» не существует.
Синтаксис и основные опции
Основное назначение команды route – добавление и удаление сетевых маршрутов для системного ядра, а также просмотр содержимого таблицы маршрутизации. Эта команда, хотя и работает в разных UNIX-подобных системах одинаково, однако имеет резко отличающийся синтаксис в зависимости от используемой системы.
В общем случае прототипом команды route является следующая запись:
route add [-net|-host] <IP/Net> netmask gw <Gateway IP> dev <Int>X
Например:
$ route add -net 127.0.0.0 netmask 255.0.0.0 metric 1024 dev lo
Эта команда добавит шлюз с обратной связью через виртуальное устройство lo, которое используется для этой цели в Linux-системах. Опции -net и -host используются для указания адреса, характеризующего либо сеть, либо узел соответственно как пункты назначения. Для определения подсети служит опция netmask, для задания приоритета шлюза — опция metric. Сетевой интерфейс обозначается опцией dev. Кроме описанных выше для команды route также существуют и другие используемые ей опции, которые приведены в следующей таблице:
Опция | Назначение |
del | Удаление маршрута |
gw | Шлюз, через который должны достигаться сеть или узел. Задаётся в виде имени узла или точечной записи адреса. |
mss | Устанавливает значение MTU (максимальную величину пакета) в байтах. |
window | Устанавливает размер TCP-окна для задаваемого шлюза в байтах. Обычно используется в сетях AX.25. |
irtt | Устанавливает начальное время отклика для TCP-соединений по данному маршруту в миллисекундах. |
reject | Задаёт блокирующий маршрут, который должен приводить к остановке процедуры поиска маршрутов. Полезно при скрытии сетей для использования в них шлюз по-умолчанию. |
-F | Заставляет работать с таблицей маршрутизации ядра. Эта опция в большинстве систем используется по-умолчанию, поэтому часто опускается. |
-C | Заставляет работать с кэшем маршрутизации ядра. |
-v | Включает подробный режим работы команды route. |
-n | Использование числового формата адресов вместо попыток определения символьных наименований узлов. Можно использовать в случае определения проблем с соединениями к DNS. |
-e | Использовать формат вывода команды netstat для отображения содержимого таблицы маршрутов. Опция -ee сгенерирует самый подробный отчёт с полными наименованиями параметров таблицы маршрутов. |
Примеры использования
Определить маршрут к сети, которая должна быть достигнута через сетевой интерфейс eth0:
$ ifconfig eth0 nodeone netmask 255. 255.255.0
$ route add -net 192.168.1.0
Здесь для команды route не указывается сам интерфейс, поскольку предполагается, что узлу nodeone соответствует адрес 192.168.1.2. Далее, route «узнаёт», что маршрут нужно проложить именно через eth0 благодаря тому, что системное ядро анализирует все доступные интерфейсы на предмет их конфигурации и сравнивает адрес пункта назначения с сетевой частью сетевых (сконфигурированных) интерфейсов. В данном случае ядро обнаруживает, что eth0 – тот интерфейс (с адресом 192.168.1.2), которому соответствует конечный адрес, т. е. 192.168.1.0.
Задание шлюза по-умолчанию:
$ route add default gw 192.168.1.1 eth0
Доступ в локальную сеть Ethernet через сетевой интерфейс eth0:
$ route add -net 192.168.10.0 netmask 255.255.255.0 eth0
Здесь 192.168.10.0 – сеть, к которой нужно установить доступ (маршрут).
Вывод содержимого таблицы маршрутов ядра осуществляется командой route без параметров, для подробных результатов используется опция -ee.
Также можно использовать сокращённую запись для задания маски подсети:
$ route add -net 192.168.10.0/24 eth0
Следует отметить, что шлюзы, установленные командой route будут существовать до перезагрузки системы. Для их использования на постоянной основе необходимо нужные команды прописать в файле. В Ubuntu это /etc/network/interfaces.
Например для настройки маршрутизации сети 192.168.10.0/24 через шлюз 192.168.10.1 интерфейс eth0, это команда
$ route add -net 192.168.10.0/24 gw 192.168.10.1 eth0
файл /etc/network/interfaces будет выглядеть следующим образом
auto lo
iface lo inet loopbackauto eth0
iface eth0 inet static
address 192.168.10.8
hwaddress ether 00:E0:4C:A2:C4:48
netmask 255.255.255.0
broadcast 192.168.10.255
up route add -net 192.168.10.0/24 gw 192.168.10.1 eth0auto eth2
iface eth2 inet static
address 172.16.0.34
netmask 255.255.255.0
gateway 172. 16.0.1
broadcast 172.16.0.255
В Centos/Redhat это файл /etc/sysconfig/network-scripts/route-eth0 для интерфейса eth0 если же название интерфейса другое, то название файла будет route-<название интерфейса>. Если этого файла нет, то его нужно создать. Для настройки выше указанного примера, добавьте в файл следующие строки
192.168.10.0/24 via 192.168.10.1
Также можно прописать и несколько дополнительных маршрутов, для этого просто указываем их в новой строке. После чего сохраняем файл и рестартуем сетевую службу
systemctl restart network
Если вы нашли ошибку, пожалуйста, выделите фрагмент текста и нажмите Ctrl+Enter.
Командная строка — команда Route
Главная страницаПолезноеКомандная строка (CMD)КомандыКоманда Route
Применяется с целью выдачи и внесения корректировок в локальную таблицу IP-маршрутизации. Если не задавать никаких параметров при вводе в командную строку, то будет получена справочная информация.
Написание
route [-f] [-p] [команда [финальная_точка] [mask маска_сети] [шлюз] [metric метрика]] [if интерфейс]]
Расшифровка значений
-f
Предусматривает осуществление очистки таблицы маршрутизации от записей, не относящихся к категории узловых маршрутов и тех, которые замыкаются сами на себя, а также являющихся многоадресной рассылкой.
-p
Если прописывание указанного параметра происходит совместно с командой add, то предполагается добавление установленного маршрута в реестр. Он станет использоваться с целью инициализации таблицы IP-маршрутизации. Подобный процесс станет осуществляться постоянно, в случае запуска TCP/IP.
финальная_точка
Позволяет установить, какую именно финальную точку будет иметь конкретный маршрут. Имеется несколько вариантов: IP-адрес в сети, маршрута к узлу или установленное по умолчанию значение.
mask маска_сети
Задает маску сети и она основывается на финальной точке. Следует сказать о том, что допускается не прописывать предложенный параметр. В такой ситуации, станет применяться 255.255.255.255.
шлюз
Устанавливается IP-адрес для осуществления отправки или дальнейшего перехода, где обеспечивается доступ к некоторому набору адресов.
metric метрика
Указывается число, которое лежит в диапазоне от 1 до 9999. Целочисленная метрика предусматривает использование в тех ситуациях, если надо выбрать подходящий маршрут в таблице маршрутизации. Допускается останавливать внимание на одно или нескольких из них.
if интерфейс
Устанавливается индекс интерфейса. Именно через него будет доступна предписанная финальная точка. Можно получить полный перечень сопутствующей информации, если ввести route print. Допускается использование параметров индексов в двух типах систем счисления: десятичной и шестнадцатеричной.
Настройка
- Microsoft Windows 2000
- Microsoft Windows XP
- Microsoft Windows Servers
- Microsoft Windows Vista
- Microsoft Windows 7
- Microsoft Windows 8
- Microsoft Windows 10
Полезная информация
- Синий экран смерти (BSOD)
- Коды ошибок
- Способы устранения
- Командная строка (CMD)
- Переменные
- Команды
- Примеры bat файлов
- Примеры Rundll32. exe
- Windows Script Host (WSH)
- Объект WshShell
- Объект FileSystemObject
- Объект RegExp
- Объект Dictionary
- Объект Shell
- Константы VBScript
- Функции VBScript
- Объект IE и WebBrowser
- Объект WScript
- Объект WshNetwork
- Basic In/Out System (BIOS)
- AMI bios
- AWARD bios
- Phoenix bios
- UEFI bios
- Реестр Windows
- Хитрости реестра Windows
- Скачать Live CD
- Полезные статьи
- Часто задаваемые вопросы
- Стоит ли переходить на Windows 10?
- Не открывается флешка на компьютере?
- Как разбить жесткий диск на разделы?
- Удалить баннер с рабочего стола
- Лучшие бесплатные антивирусы 2016-2017 года
- Не открывается Вконтакте и другие сайты
- Как убрать всплывающие сайты и рекламу в браузере
Справка и примеры команд Linux Route
Обновлено: 13.03.2021 автором Computer Hope
В Unix-подобных операционных системах команда route отображает или изменяет таблицу IP-маршрутизации.
На этой странице описывается Linux-версия маршрута .
- Описание
- Синтаксис
- Примеры
- Связанные команды
- Справка по командам Linux
Описание
В компьютерных сетях маршрутизатор — это устройство, отвечающее за пересылку сетевого трафика. Когда дейтаграммы поступают на маршрутизатор, маршрутизатор должен определить наилучший способ их передачи.0027 маршрут их к месту назначения.
В Linux, BSD и других Unix-подобных системах команда route используется для просмотра и внесения изменений в таблицу маршрутизации ядра. Синтаксис команды отличается в разных системах; здесь, с особым синтаксисом команд, мы будем обсуждать версию для Linux.
Запуск route в командной строке без каких-либо параметров отображает записи таблицы маршрутизации:
маршрут
Таблица IP-маршрутизации ядра Шлюз назначения Флаги Генмаски Метрика Ссылка Использование Iface по умолчанию 192. 168.1.2 0.0.0.0 UG 1024 0 0 eth0 192.168.1.0 * 255.255.255.0 U 0 0 0 eth0
Это показывает нам, как сейчас настроена система. Если в систему приходит пакет и адрес назначения находится в диапазоне от 192.168.1.0 до 192.168.1.255 , то он перенаправляется на шлюз * , то есть 0.0.0.0 — специальный адрес, представляющий недопустимый или несуществующий пункт назначения. Здесь наша система не будет маршрутизировать эти пакеты.
Если пункт назначения не входит в этот диапазон IP-адресов, он перенаправляется на шлюз по умолчанию (в данном случае 192.168.1.2 , и эта система определяет, как перенаправить трафик на следующий шаг к месту назначения.
Техническое описание
route управляет таблицами IP-маршрутизации ядра. Его основное использование заключается в настройке статических маршрутов к определенным хостам или сетям через интерфейс после того, как он был настроен с помощью программы ifconfig.
Когда используются опции добавить или del , route изменяет таблицы маршрутизации. Без этих опций маршрут отображает текущее содержимое таблиц маршрутизации.
Синтаксис
маршрут [-CFvnee]
route [-v] [-A family ] add [-net|-host] target [сетевая маска Nm ] [gw Gw ] [метрика N ] i [mss M ] [окно W ] [irtt m ] [отклонить] [mod] [dyn] [восстановить] [[dev] Если ]
route [-v] [-A family ] del [-net|-host] target [gw Gw ] [сетевая маска Nm ] [метрика N ] [[dev] Если ]
маршрут [-V] [--версия] [-h] [--help]
Опции
-А семейство | Используйте указанное семейство адресов (например, ‘ inet ‘; используйте ‘ route —help ‘ для получения полного списка). |
-Ф | Работа с таблицей маршрутизации FIB (Forwarding Information Base) ядра. Это значение по умолчанию. |
-С | Работа с кэшем маршрутизации ядра. |
-в | Выберите подробную операцию. |
-н | Показывать числовые адреса вместо попытки определить символические имена хостов. Это полезно, если вы пытаетесь определить, почему маршрут к вашему серверу имен исчез. |
-е | Использовать формат netstat для отображения таблицы маршрутизации. -ee генерирует очень длинную строку со всеми параметрами из таблицы маршрутизации. |
дел | Удалить маршрут. |
добавить | Добавить новый маршрут. |
цель | Целевая сеть или хост. Вы можете указать IP-адреса в десятичном формате с точками или в именах хостов/сетей. |
-нетто | Целью является сеть. |
-хост | Целью является хост. |
сетевая маска NM | При добавлении сетевого маршрута необходимо использовать сетевую маску. |
ГВт ГВт | Направлять пакеты через шлюз. ПРИМЕЧАНИЕ. Сначала должен быть доступен указанный шлюз. Обычно это означает, что вам необходимо заранее настроить статический маршрут к шлюзу. Если вы укажете адрес одного из ваших локальных интерфейсов, он будет использоваться для принятия решения об интерфейсе, маршрутизирующем пакеты. Это хак совместимости в стиле BSD. |
Метрическая система M | Установите для поля метрики в таблице маршрутизации (используемой демонами маршрутизации) значение M . |
мсс М | Установите максимальный размер сегмента TCP (MSS) для соединений по этому маршруту равным M байт. По умолчанию используется значение MTU устройства за вычетом заголовков или меньшее значение MTU при обнаружении пути MTU. Этот параметр можно использовать для принудительной передачи TCP-пакетов меньшего размера на другом конце, когда обнаружение пути mtu не работает (обычно из-за неправильно настроенных брандмауэров, блокирующих ICMP-фрагментацию) |
Окно Ш | Установите размер окна TCP для соединений по этому маршруту равным Вт байт. Это используется только в сетях AX.25 и с драйверами, не способными обрабатывать встречные кадры. |
ирт м | Установите начальное время приема-передачи ( irtt ) для соединений TCP по этому маршруту на м миллисекунд ( 1 — 12000 ). Это используется только в сетях AX.25. Если опущено, значение по умолчанию RFC 1122 равно 9.0005 300 мс используется. |
брак | Установите блокирующий маршрут, который приведет к сбою поиска маршрута. Это, например, используется для маскировки сетей перед использованием маршрута по умолчанию. Это НЕ для брандмауэра. |
мод , дин , восстановить | Установите динамический или модифицированный маршрут. Эти флаги предназначены для диагностических целей и обычно устанавливаются только демонами маршрутизации. |
разработчик Если | Принудительно связать маршрут с указанным устройством, так как в противном случае ядро попытается определить устройство самостоятельно (путем проверки уже существующих маршрутов и спецификаций устройства, а также места добавления маршрута). В большинстве обычных сетей вам это не понадобится. Если dev Если является последней опцией в командной строке, слово dev можно опустить, так как оно используется по умолчанию. В противном случае порядок модификаторов маршрута ( метрика — сетевая маска — gw — dev ) не имеет значения. |
Примеры
маршрут -n
Показывает таблицу маршрутизации для всех IP-адресов, привязанных к серверу.
маршрут добавить -net 192.56.76.0 сетевая маска 255.255.255.0 dev eth0
добавляет маршрут к сети 192.56.76.x через «eth0» Модификатор сетевой маски класса C здесь не нужен, потому что > 192.* — это IP-адрес класса C. Слово « dev » здесь можно опустить.
маршрут добавить -net 224.0.0.0 сетевая маска 240.0.0.0 dev eth0
Эта команда устанавливает все IP-маршруты класса D (многоадресные) для прохождения через « eth0 ». Это правильная нормальная конфигурация для многоадресного ядра.
arp — Управление системным кешем ARP.
ifconfig — Просмотр или изменение конфигурации сетевых интерфейсов.
ip — отображение и управление информацией о маршрутизации, устройствах, политике маршрутизации и туннелях.
netstat — выводит информацию о сетевых подключениях, таблицах маршрутизации, статистике интерфейсов, маскарадных подключениях и членстве в многоадресной рассылке.
маршрутная команда
маршрутная команда
[ Предыдущий |
Далее |
Содержание |
Глоссарий |
Главная |
Поиск ]
Справочник по командам AIX версии 4.3, том 4
Назначение
Ручное управление таблицами маршрутизации.
Синтаксис
маршрут [ -n ] [ -q ] [ -v ] Команда [ Семья ] [ [ -net | -host ] Назначение [ -маска сети [ Адрес ] ] Шлюз ] [ Аргументы ]
Описание
Команда route позволяет вручную вносить записи в таблицы сетевой маршрутизации. Команда route различает маршруты к хостам и маршруты к сетям, интерпретируя сетевой адрес Переменная назначения , которая может быть указана символическим именем или числовым адресом. Команда route преобразует все символические имена в адреса, используя либо файл /etc/hosts , либо сервер сетевых имен.
Маршруты к конкретному узлу отличаются от маршрутов к сети интерпретацией интернет-адреса, связанного с пунктом назначения. Необязательные ключевые слова -net и -host заставляют пункт назначения интерпретироваться как сеть или хост соответственно. Если пункт назначения имеет локальную часть адреса INADDR_ANY или если пункт назначения является символическим именем сети, то предполагается, что маршрут ведет к сети; в противном случае предполагается, что это маршрут к хосту.
Например, 128.32 интерпретируется как -host 128.0.0.32 ; 128.32.130 интерпретируется как -host 128. 32.0.130 ; -net 128.32 интерпретируется как 128.32.0.0 ; а -net 128.32.130 интерпретируется как 128.32.130.0 .
Если маршрут проходит через интерфейс, а не через шлюз, следует указать аргумент -interface . Указанный шлюз — это адрес хоста в общей сети, указывающий интерфейс, который будет использоваться для передачи.
Аргумент -netmask должен сопровождаться параметром адреса (чтобы он интерпретировался как маска сети). Можно переопределить неявную сетевую маску, сгенерированную в случае -inet , убедившись, что эта опция соответствует параметру Destination .
Все символические имена, указанные для пункта назначения или шлюза, сначала просматриваются как имя хоста с помощью подпрограммы gethostbyname . Если это не удается, используется подпрограмма getnetbyname для интерпретации имени как сетевого имени.
Примечание. Маршрут использует сокет маршрутизации и новые типы сообщений RTM_ADD, RTM_DELETE и RTM_CHANGE. Таким образом, только пользователь root может изменять таблицы маршрутизации.
Если указана команда flush или -f , route «сбросит» или очистит таблицы маршрутизации всех записей шлюза. Можно выбрать сброс только тех маршрутов, пункты назначения которых относятся к данному семейству адресов, указав необязательное ключевое слово, описывающее, какое семейство адресов.
Команда netstat -r отображает текущую информацию о маршрутизации, содержащуюся в таблицах маршрутизации.
Флаги
-н | Отображает имена хостов и сетей численно, а не символически, при сообщении результатов сброса или любого действия в подробном режиме. |
-q | Задает тихий режим и подавляет все выходные данные. |
-в | Задает подробный режим и печатает дополнительные сведения. |
-нетто | Указывает, что параметр Destination следует интерпретировать как сеть. |
-сетевая маска | Указывает сетевую маску для адреса назначения. Убедитесь, что этот параметр соответствует параметру Destination . |
-хост | Указывает, что параметр Destination следует интерпретировать как узел. |
Маршрут по умолчанию — хост (один компьютер в сети). Если ни параметр -net , ни параметр -host не указаны, но указана сетевая часть адреса, предполагается, что маршрут проходит в сеть. Хостовая часть адреса равна 0 (ноль).
Параметры
Аргументы | Задает один или несколько следующих аргументов. Если n указывается как переменная для аргумента, значение n переменная является положительным целым числом.
|
Команда | Указывает одну из пяти возможностей:
|
Семья | Задает семейство адресов. Семейство адресов -inet используется по умолчанию. Семейство адресов -xns указывает, что все последующие адреса относятся к семейству адресов Xerox Network System (XNS). |
Пункт назначения | Идентифицирует хост или сеть, к которой вы направляете маршрут. Параметр Destination может быть указан либо символическим именем, либо числовым адресом. |
Шлюз | Идентифицирует шлюз, которому адресованы пакеты. Параметр Gateway может быть указан либо символическим именем, либо числовым адресом. |
Примеры
Ниже приведены примеры использования 9Команда 0005 route в сети TCP/IP и сети XNS соответственно:
Примеры Интернета
- Чтобы установить маршрут, чтобы компьютер в одной сети мог отправлять сообщения на компьютер в другой сети, введите:
маршрут добавить 192.100.201.7 192.100.13.7
Адрес 192.100.201.7 — это адрес принимающего компьютера (параметр Destination ). Адрес 192.100.13.7 — это адрес компьютера-маршрутизатора (шлюза 9).параметр 0028).
- Чтобы установить маршрут для отправки сообщения любому пользователю в определенной сети, введите:
маршрут добавить -net 192. 100.201.0 192.100.13.7
Адрес 192.100.201.0 соответствует адресу принимающей сети (параметр Destination ). Адрес 192.100.13.7 — это адрес сети маршрутизации (параметр Gateway ).
- Чтобы установить шлюз по умолчанию, введите:
добавить маршрут 0 192.100.13.7
Значение 0 или ключевое слово по умолчанию для параметра Destination означает, что любые пакеты, отправляемые в пункты назначения, не определенные ранее и не находящиеся в сети с прямым подключением, проходят через шлюз по умолчанию. Адрес 192.100.13.7 — это адрес шлюза, выбранный по умолчанию.
- Чтобы очистить таблицу узловых шлюзов, введите:
маршрут -f
Примеры XNS
- Чтобы добавить маршрут к интерфейсу XNS, введите:
маршрут добавить -xns 120 110:02.60.8c.2c.a4.98
Это добавляет маршрут xns к сети назначения 120 через шлюз 110:02.