Linux

Настройка сетевых маршрутов в CentOS

Для управления маршрутизацией в Linux предпочтительно исопльзовать утилиту ip, а не route. Команда route не позволяет настраивать расширенные возможности маршрутизации (например, политики маршрутизации), и не покажет специальные настройки маршрутизации, если они уже сделаны через ip.

Просмотр таблицы маршрутизации в Linux

Чтобы вывести текущую таблицу маршрутизации в Linux выполните команду:

ip route

  • default via 192.168.40.1 dev ens192 – шлюз по умолчанию, в данном примере работающий через интерфейс enp0s3. Если для target адреса в таблице маршрутизации отсутствует маршрут, то такой пакет отправляется через данный шлюз (маршрут по умолчанию)
  • 192.168.40.0/24 dev ens192 proto kernel scope link src 192.168.40.197 - статический маршрут для сети 192.168.40.0/24 через адрес 192.168.40.197, который прописан на интерфейсе
  • proto kernel – маршрут создан ядром (proto static – маршрут добавлен администратором)
  • metric – приоритет маршрута (чем меньше значение metric, тем выше приоритет). При наличии двух маршрутов с одинаковой метрикой (не стоит так делать!), ядро начинает выбирать маршруты случайным образом.

Чтобы узнать через какой интерфейс (шлюз) должен маршрутизироваться трафик к определенному IP адресу используется команда:

ip route get 192.168.2.45

Как добавить или удалить статический маршрут?

Чтобы добавить новый маршрут к определенной IP подсети в таблицу маршрутизации Linux, нужно выполнить следующую команду:

ip route add 192.168.0.0/24 via 192.168.40.1

Таким образом, мы добавим маршрут для IP сети 192.168.0.0/24 через шлюз 192.168.40.1

Также можно добавить отдельный маршрут для одного IP адреса (хоста):

ip route add 192.168.1.0 via 192.168.40.1

Маршруты, добавленные таким образом являются временным и будут работать до перезагрузки сетевой службы или сервера.

Чтобы удалить созданный вручную маршрут, выполните:

ip route del 192.168.0.0/24

Чтобы добавить постоянный маршрут, нужно создать файл для этого маршрута, либо добавить правило в файл rc.local (выполняется при загрузке сервера).

Чтобы добавить постоянный (статический) маршрут, нужно знать имя сетевого интерфейса, который будет использоваться для маршрутизации. Узнать имя сетевого интерфейса можно командой:

ip a

В моем случае, интерфейс ens192

Далее открываем следующий файл:

nano /etc/sysconfig/network-scripts/route-ens192

И добавляем туда строку с маршрутом:

192.168.0.0/24 via 192.168.40.1

После добавления маршрута в файл нужно перезапустить сервис network:

service network restart

После перещаауска сетевого сервиса, в таблице маршрутизации появился статический маршрут.

Также можно добавить команду добавления нового маршрута в файл rc.local, чтобы он автоматически добавлялся при загрузке сервера. Откройте файл:

nano /etc/rc.local

И укажите команду добавления маршрута:

ip route add 192.168.0.0/24 via 192.168.40.1

Теперь, если ваш сервер будет перезагружен, маршрут пропишется автоматически при загрузке системы.

Изменить маршрут в Linux

Чтобы изменить уже существующий маршрут, можно использовать команду ip route replace:

ip route replace 192.168.0.0/24 via 192.168.40.1

Чтобы сбросить все временные маршруты в таблице маршрутизации, просто перезапустите сетевой сервис:

service network restart

Изменить маршрут по умолчанию

Вы можете удалить маршрут по-умолчаню с помощью команды ip route del:

ip route del default via 192.168.1.1 dev ens192

Чтобы указать новый маршрут по-умолчанию в CentOS используется команда:

ip route add default via 192.168.1.2 (маршрут через IP адрес шлюза)

ip route add default via ens192 (маршрут через имя устройства)

Чтобы изменить параметры маршрута по умолчанию, используется команда:

ip route replace default via 192.168.1.2