Смекни!
smekni.com

Статическая IP-маршрутизация (стр. 2 из 2)

Рабочая станция ws.4.2:

ifconfig ep0 inet 192.168.4.137 netmask 255.255.255.240

route add default 192.168.4.129

А эту сеть (тоже класса C) сегментируем маршрутизатором, который разобьет сеть на две равные части.

Шлюз:

ifconfig ed3 inet 192.168.5.1 netmask 255.255.255.128

route add -net 192.168.5.128 -netmask 255.255.255.128 192.168.5.127

Рабочая станция ws.5.1:

ifconfig ep0 inet 192.168.5.7 netmask 255.255.255.128

route add -net 192.168.5.128 -netmask 255.255.255.128 192.168.5.127

route add default 192.168.5.1

Маршрутизатор router.5:

ifconfig ep0 inet 192.168.5.127 netmask 255.255.255.128

ifconfig ep1 inet 192.168.5.129 netmask 255.255.255.128

route add default 192.168.5.1

Рабочая станция ws.5.2:

ifconfig ep0 inet 192.168.5.137 netmask 255.255.255.128

route add default 192.168.5.129

Разница с предыдущим случаем в том, что сеть разделена на сегменты, содержащие только "куглое" число IP-номеров (два в целой степени). Это особый случай, когда логичнее оформить каждую сеть отдельно.

Теперь сделаем две сети, соединенные через последовательную линию по протоколу PPP.

Шлюз:

ifconfig ed3 inet 192.168.6.1 netmask 255.255.255.0

route add -net 172.17.14.192 -netmask 255.255.255.252 192.168.6.127

route add -net 192.168.6.128 -netmask 255.255.255.240 192.168.6.127

Маршрутизатор rt.6.1:

ifconfig ep0 inet 192.168.6.127 netmask 255.255.255.128

pppd 172.17.14.193:172.17.14.194 netmask 255.255.255.252 [...]

route add -net 192.168.6.128 -netmask 255.255.255.240 172.17.14.194

route add default 192.168.6.1

pppd требует при запуске указать интерфейс, через который происходит соединение, и его параметры, но это не относится к теме и обозначено [...].

Маршрутизатор rt.6.2:

ifconfig ep0 inet 192.168.6.129 netmask 255.255.255.240

pppd 172.17.14.194:172.17.14.193 netmask 255.255.255.252 [...]

route add default 172.17.14.193

Рабочая станция ws.6.2:

ifconfig ep0 inet 192.168.6.137 netmask 255.255.255.240

route add default 192.168.6.129

Подсеть на 16 машин выделена аналогично примеру 4. Я надеюсь, разбиение сети на подсети "круглого" размера, соединенные по ppp, после усвоение прочитанного окажется под силу любому.

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

сервер DHCP должен находиться в том же сегменте локальной сети, что и его клиенты;

сервер DHCP должен корректно конфигурировать клиентов, что опять же непросто в сложной сегментированной сети.

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

Примечания:

Прозрачный - Сегмент Internet сам может быть сегментирован на уровне MAC, например, коммутатором. Прозрачность проявляется в том, что маршрутизатор, работающий на уровне IP, не должен заботиться об этом; в частности, IP-маршрутизатор никогда не пропускает broadcast сообщения (в отличие от multicast), но broadcast сообщения должны свободно распространяться по всей локальной сети сети - это нужно, в частности, для протокола ARP.

Последовательным портом в данном случае называется любой порт, выдающий данные побайтно (асинхронный COM, синхронный RS-232, принтерный LPT) в отличие от сетевого интерфейса, выдающего данные пакетами. Отличается от сетевого тем, что с поиощью последовательных интерфейсов можно связывать напрямую ровно два компьютера, а значит, такой способ не нуждается в адресации пакетов на MAC-уровне.

DNS - Domain Name Service, позволяющий узнать IP-номер и некоторую другую информацию о машине по доменному имени, а также доменное имя по IP-номеру. В частности, зона определения имени по номеру может быть делегирована только на сеть класса A, B или C и никак иначе. :-(

System V:

BSD: ifconfig интерфейс inet адрес netmask маска alias
Linux: ifconfig eth0:1 inet адрес netmask маска
BSD: route add -net номер -netmask маска шлюз
Linux: route add -net номер netmask маска шлюз

Соответствие между интерфейсом eth0 и парой Port/IRQ записано в /etc/lilo.conf; после изменения надо запустить еще что-то.

Windows 3.11

ifconfig интерфейс inet адрес netmask маска

прописывается в "Свойствах TCP/IP" данного интерфейса.

ifconfig интерфейс inet адрес netmask маска alias

прописывается в "Дополнительных свойствах".

route add default шлюз

задается как "Default Gateway".

route add -net номер -netmask маска шлюз

вводится с командной строки

route add номер MASK маска шлюз

Эти команды реально выполняются, однако, как правило, они задаются иначе. В файле /etc/sysconfig пишется

network_interfaces="ep0 lo0"

ifconfig_ep0="inet 192.168.1.5 netmask 255.255.255.0"

ifconfig_lo0="inet localhost"

Эти строки обрабатываются файлом /etc/netstart

# Set up all the network interfaces, calling startup scripts if needed

for ifn in ${network_interfaces}; do

eval ifconfig_args=\$ifconfig_${ifn}

ifconfig ${ifn} ${ifconfig_args}

ifconfig ${ifn}

done

if [ -n "$defaultrouter" -a "x$defaultrouter" != "xNO" ] ; then

static_routes="default ${static_routes}"

route_default="default ${defaultrouter}"

fi

# Set up any static routes. This should be done before router discovery.

if [ "x${static_routes}" != "x" ]; then

for i in ${static_routes}; do

eval route_args=\$route_${i}

route add ${route_args}

done

fi

а localhost определяется по файлу /etc/hosts, в котором содержится

127.0.0.1 localhost.домен localhost

и некоторые другие адреса/имена, которые машина должна знать даже в случае недоступности DNS-сервера; как минимум, там кроме loopback содержатся адреса остальных интерфейсов данной машины, ассоциированные с ее доменным именем в полной и короткой формк.

Протокол ARP используется в сетях, имеющих свою собственную нумерацию (Ethernet, TokenRing, X.25) и нужен для того, чтобы не прописывать вручную соответствие IP-адресов номерам сетевых адаптеров. После старта системы таблицы ARP пусты; если приходит IP-пакет от какой-либо станции, фиксируется соответствие ее IP-номера номеру ее сетевой карты. Если надо послать пакет по IP-номеру, для которого неизвестен номер сетевой карты, посылается широковещательное (в понимании локальной сети) сообщение.

Зацикливание пакета в некоторых алгоритмах рассматривается как результат неправильной маршрутизации. Каждый пакет имеет конечное время жизни, задаваемое отправителем и не превышающее 255 секунд, причем каждый маршрутизатор, через который проходил пакет, уменьшает это число как минимум на единицу, а значит пакет не может бесконечно метаться между маршрутизаторами - он умрет и о его смерти известят отправителя отдельным пакетом (на этом основана работа traceroute). Тем не менее некоторые маршрутизаторы во избежание засорения полосы пропускания сами убивают пакеты, которые, судя по их таблицам маршрутизации, следует отправлять через тот интерфейс, через который они пришли.

Протокол DHCP (Dynamic Host Configure Protocol) по запросу машины выдает ей IP-адрес, маску, номер DNS-сервера и т.д. вплоть до загружаемой через сеть операционной системы. Как правило, применяется в варианте, когда запрашивающая машина не знает ни своего адреса, ни адреса DHCP-сервера; в этом случае она находит сервер, посылая широковещательный запрос, а значит, они должны быть в одном сегменте локальной сети.