Настроение сейчас - ниже среднегоМногие новички в сетях и FreeBSD сталкиваются с вопросом:
“Как соединить две сети если сервер на FreeBSD имеет физическое подключение к обеим сетям ?”
Иными словами сервер FreeBSD должен выступать в роли router (маршрутизатор).
Итак, что мы имеем:
Ethernet сеть
Две подсети класса “С” (/24 - маска 255.255.255.0)
Сервер FreeBSD с двумя сетевыми картами
Клиенты в обеих подсетях
Наша задача, чтобы клиенты из подсети 192.168.1.0/24 могли обмениваться трафиком с клиентами из подсети 192.168.0.0/24.
Сначала настроим сервер FreeBSD и заставим его передавать (маршрутизировать) пакеты из одной подсети в другую.
За это отвечает параметр net.inet.ip.forwarding, посмотрим в какое значение он имеет:
[root@freebsd ~]# sysctl net.inet.ip.forwarding
net.inet.ip.forwarding: 0
На данный момент его значение “0″, а это значит, что сервер FreeBSD не будет выполнять маршрутизации.
Включим эту функцию:
[root@freebsd ~]# sysctl net.inet.ip.forwarding=1
net.inet.ip.forwarding: 0 -> 1
Так мы изменили значение с “0″ на “1″. Теперь нужно сделать, так чтобы после ребута это значение всегда было 1-цой. Это можно сделать 2-мя способами:
в файл /etc/rc.conf добавить строчку: gateway_enable=”YES”
в файл /etc/sysctl.conf добавить строчку: net.inet.ip.forwarding=1
На сервере у нас есть две сетевые карты и соответственно два интерфейса: em0 и em1.
Пусть em0 “смотрит” в сеть слева, а em1 в сеть справа. Назначим IP-адреса для интерфейсов FreeBSD сервера:
[root@freebsd ~]# ifconfig em0 add 192.168.1.1/24
[root@freebsd ~]# ifconfig em1 add 192.168.0.1/24
--------------------------------------------------------------------------------
Примечание:
Если на команду ifconfig вы получаете ответ:
command not found
воспользуйтесь командой
[root@virus ~]# whereis ifconfig
ifconfig: /sbin/ifconfig /usr/share/man/man8/ifconfig.8.gz /usr/src/sbin/ifconfig
которая укажет где именно располагается утилита ifconfig
как видно из результата выполнения команды whereis утилита ifconfig находится /sbin/ifconfig
вводите полный путь до утилиты ifconfig, тогда надпись command not found появляться не будет и команда будет выполняться
--------------------------------------------------------------------------------
Посмотрим что получилось:
[root@freebsd ~]# ifconfig -a
em0: flags=8843 metric 0 mtu 1500
ether 00:02:a5:4e:92:48
inet 192.168.1.1 netmask 0xffffff00 broadcast 192.168.1.255
media: Ethernet autoselect (100baseTX )
status: active
em1: flags=8802 metric 0 mtu 1500
ether 00:02:a5:4e:92:49
inet 192.168.0.1 netmask 0xffffff00 broadcast 192.168.0.255
media: Ethernet autoselect (100baseTX )
status: activeРассмотрим что все это значит :
em0 и em1 - имена сетевых интерфейсов
флаг UP - означает что сетевая карта включена, если этого флага не будет, то пакеты не будут приниматься на этом интерфейсе (для включения воспользуйтесь командой: ifconfig ИМЯ_ИНТЕРФЕЙСА up)
ether - это mac-адрес этой сетевой карты
inet - назначенный IP-адрес для этого интерфейса и broadcast адрес для этой подсети
media - информация о скорости и дуплексе интерфейса
status - текущий статус интерфейса. Если status: no carrier, то это означает, что на сетевой карте нет линка.
Сохраним настройки, чтобы IP-адреса назначались интерфейсам после ребута сервера, для этого необходимо добавить в файл /etc/rc.conf следующие строчки:
ifconfig_em0=”inet 192.168.1.1 netmask 255.255.255.0″
ifconfig_em1=”inet 192.168.0.1 netmask 255.255.255.0″
Если на сервере вы используете firewall, например ipfw, то добавим правила разрешающие проход пакетов из одной сети в другую:
ipfw add 100 allow ip from 192.168.1.1/24 to 192.168.0.1/24
ipfw add 110 allow ip from 192.168.1.0/24 to 192.168.1.1/24
Теперь настройте клиентские компьютеры:
Выставить IP-адрес из нужной подсети: 192.168.1.ХХХ или 192.168.0.ХХХ
Выставить маску подсети 255.255.255.0
Выставить шлюз по умолчанию: для подсети 192.168.1.ХХХ это 192.168.1.1, а для подсети 192.168.0.ХХХ это 192.168.0.1 (именно эти IP-адреса на интерфейсах нашего FreeBSD сервера)
Наступило время проверить есть ли связь сервера и клиентов. Для этого возьмем заведомо рабочий клиентский компьютер из 2-х сетей, например это будут компьютеры с IP-адресами:
192.168.1.11
192.168.0.15
Воспользуемся утилитой ping на сервере:
[root@freebsd ~]# ping 192.168.1.11
Если результат будет таким:
PING 192.168.1.11 (192.168.1.11): 56 data bytes
64 bytes from 192.168.1.11: icmp_seq=0 ttl=64 time=0.466 ms
64 bytes from 192.168.1.11: icmp_seq=1 ttl=64 time=0.238 ms
64 bytes from 192.168.1.11: icmp_seq=2 ttl=64 time=0.272 ms
^C
— 192.168.1.11 ping statistics —
3 packets transmitted, 3 packets received, 0.0% packet loss
round-trip min/avg/max/stddev = 0.238/0.325/0.466/0.100 ms
Значит все хорошо и связь между сервером и клиентом есть. Проделайте тоже самое с 192.168.0.15.
Если результат ping отрицательный, то убедитесь что на клиентском компьютере правильно выставлен IP-адрес и маска подсети, а так же наличие линка на сетевой карте.
Теперь можно попробовать проверить связь между клиентскими компьютерами из разных подсетей.
Так же воспользуемся утилитой ping, но уже на компьютере с IP-адресом 192.168.1.11:
ping 192.168.0.15
Если ответ есть, то и свзяь между компьютерами из разных подсетей есть.
Если ответа нет, то воспользуемся утилитой tracert (для Windows) или traceroute (для FreeBSD):
tracert 192.168.0.15
Если сразу “идут звездочки”:
1 * * *
То проверьте правильность выставление шлюза по умолчанию.
Если трасса выглядит так:
1 192.168.1.1 (192.168.1.1) 0.421 ms 0.447 ms 0.485 ms
2 * * *
То пакет доходит до сервера, убедитесь что firewall сервера не блокирует пакеты и что клиентский компьютер с IP-адресом 192.168.0.15 правильно настроен и “видит” сервер (проверьте IP-адрес, маску подсети, шлюз по умолчанию и наличие ping до сервера)
Вы все проверили, но по прежнему ничего не работает ? Воспользуемся утилитой tcpdump на сервере, которая покажет пакеты проходящие через интерфейсы сервера:
[root@freebsd ~]# tcpdump -ni em0
и
[root@freebsd ~]# tcpdump -ni em1
Запустите пинг с одного клиентского компьютера из одной подсети на другой клиентский компьютер в другой подсети (как мы делали в примерах выше) и смотрите в вывод команды tcpdump на сервере, который будет примерно таким:
[root@freebsd ~]# tcpdump -ni em0
12:17:23.398376 IP 192.168.1.11 > 192.168.0.15: ICMP echo request, id 49222, seq 0, length 64
12:17:24.399906 IP 192.168.1.11 > 192.168.0.15: ICMP echo request, id 49222, seq 1, length 64
Т.е. компьютер 192.168.1.11 посылает пакет ICMP echo request до компьютера 192.168.0.15, но ответов мы не видим. Посмотри передает ли сервер эти пакеты на другую сетевую карту:
[root@freebsd ~]# tcpdump -ni em1
12:21:18.167017 IP 192.168.1.11 > 192.168.0.15: ICMP echo request, id 50246, seq 4, length 64
12:21:19.168022 IP 192.168.1.11 > 192.168.0.15: ICMP echo request, id 50246, seq 5, length 64
Видим, что запросы передаются на другой интерфейс сервера, но ответов по прежнему нет. Проверьте настройки компьютера 192.168.0.15 и отсутствие у него проблем с физическим подключением к сети.
Когда все работает вывод будет таким:
12:21:17.165998 IP 192.168.1.11 > 192.168.0.15: ICMP echo request, id 50246, seq 3, length 64
12:21:17.171199 IP 192.168.0.15 > 192.168.1.11: ICMP echo reply, id 50246, seq 3, length 64
12:21:18.167017 IP 192.168.1.11 > 192.168.0.15: ICMP echo request, id 50246, seq 4, length 64
12:21:18.171353 IP 192.168.0.15 > 192.168.1.11: ICMP echo reply, id 50246, seq 4, length 64
Мы видим стандартый вывод “запрос-ответ”, когда на пакет ICMP echo request приходит ответ в виде пакета ICMP echo reply