The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]

[FreeBSD] Создание моста-фильтра на основе FreeBSD. (freebsd bridge firewall filter route ipfw)


<< Предыдущая ИНДЕКС Поиск в статьях src Установить закладку Перейти на закладку Следующая >>
Ключевые слова: freebsd, bridge, firewall, filter, route, ipfw,  (найти похожие документы)
From: http://securityportal.ru <[email protected]> Subject: [FreeBSD] Создание моста-фильтра на основе FreeBSD. Оригинал: http://securityportal.ru/network/FilterBridge.html Создание моста-фильтра на основе FreeBSD. По всем вопросам,возникшим у вас пишите по адресу: [email protected] 1. Почему именно мост? 2. Конфигурация ядра. 3. Конфигурационные файлы. 4. Настройка правил для Firewall. 5. Запуск моста с фильтрацией. 6. Производительность и несколько замечаний. 7. Дополнения читателей. 1. Почему именно мост? . В некоторых случаях бывает полезно разделить одну физическую сеть на некоторые сегменты без создания подсетей и установки маршрутизаторов. Например для того, чтобы изолировать нагруженные трафиком участки сети. В дальнейшем будем рассматривать сеть на основе технологии Ethernet (Fast Ethernet) Мост работает на канальном уровне, строя адресную таблицу на основе пассивного наблюдения за трафиком, циркулирующем в подключенных к нему сегментах. В эту таблицу заносятся MAC-адреса устройств и порт моста, к которому подключен сегмент с этими устройствами. Мост передает пакеты только в том случае, если в соответствии с его таблицей адрес источника и адрес назначения подключены к разным портам. В настоящее время повсеместно используются многопортовые мосты -коммутаторы. На основе компьютера с двумя сетевыми картами можно тоже построить мост. Это позволяют сделать ОС FreeBSD и Linux. Однако эти ОС позволяют также создать мосты с фильтрацией - т.е. мост, помимо всего выполняющий и функции фильтра ip пакетов, или, как иногда его называют - firewall. Где же может применяться такой фильтрующий мост? Первое и самое очевидное - при подключении к провайдеру. Вот пример - вам выделили диапазон ip-адресов и выдали ethernet подключение к маршрутизатору провайдера, к которому вы доступа не имеете и который не выполняет абсолютно никакой фильтрации, а вам необходимо защитить свои сервера, создать DMZ... Конечно, сразу напрашивается решение - поставить програмный маршрутизатор на основе FreeBSD, выполняющий фильтрацию. Однако тут обычно и бывают сложности. Во-первых, у вас сразу уменьшится число ip-адресов на 2, т.к. маршрутизатору нужен адрес на каждый интерфейс и вам придется перекраивать выделенный блок ip-адресов, чтобы получить сеть с нормальной маской (возможно, даже теряя адреса). Во вторых, для установки маршрутизатора необходимо, чтобы провайдер прописал его на своем маршрутизаторе, чтобы тот был в курсе, куда посылать пакеты для вашего блока ip-адресов. Вот тут и придет на помощь мост с фильтрацией. Данную схему подключения можно изобразить следующим образом: Схема Или же вы просто хотите отгородить один из участков своей сети с фильтрацией проходящего в него и из него трафика. К тому же мост имеет еще одно достоинство - ему не нужны ip-адреса. Его интерфейсы могут работать без назначения ip-адресов, что делает мост прозрачным. Однако, если вы хотите уметь к нему досуп, скажем, по ssh, а не только с консоли - можно назначить один ip-адрес на один из интерфейсов, что мы и сделаем. Благодаря возможностям ipfw и dummynet вы сможете также ограничивать трафик, проходящий через мост. 2. Конфигурация ядра. . Допустим, уже имеется машина с двумя сетевыми картами, доведенная до состояния STABLE (мы работали с версией 4 - RELENG_4), ядро которой уже было собрано с поддержкой сетевыйх карт. Для того, чтобы мост заработал, сетевые карты также должны поддерживать работу в "promiscuous" режиме. Для большей произоводительности желательно, чтобы это были PCI карты. Мы использовали две 3COM 3C905B-TX. Добавим необходимые параметры в конфиг ядра: options BRIDGE # Включим поддержку firewall options IPFIREWALL # для того, чтобы добавить возможность firewall вести логи # добавим параметр: options IPFIREWALL_VERBOSE # ограничим число пакетов, о которых ядро будет сообщать: options IPFIREWALL_VERBOSE_LIMIT=10 # Добавим еще парочку нужных параметров # ICMP_BANDLIM включает ограничение полосы для # ответов icmp error # Поскольку мы дадим мосту 1 ip-адрес, # этот параметр в некоторых случаях # помогает от D.O.S. атак. options ICMP_BANDLIM # Добавим также параметр, который заблокирует # перезагрузку системы при нажатии Ctrl+Alt+Del options SC_DISABLE_REBOOT После того, как необходимые парметры добавлены, пересоберем ядро (о том, как это сделать, можно прочитать тут: http://www.freebsd.org.ru/how-to/kernelconfig.html http://www.freebsd.org.ru/how-to/kernelconfig.html . Пример конфига ядра для нашей конфигурации с картами 3COM 3C905B-TX можно взять тут http://securityportal.ru/network/bridge ). 3. Конфигурационные файлы. Для того, чтобы запустить IPFirewall, необходимо добавить несколько параметров в /etc/rc.conf. Для начала опишем необходимые параметры, а затем приведем готовый фрагмент для вставки в rc.conf. Прежде всего необходимо добавить параметр firewall_enable="YES". Параметр firewall_script="/etc/rc.firewall" укажет, какой скрипт будет запускаться для активизации правил firewall. Следующим параметром будет firewall_type. Этот параметр показывает, какой тип firewall будет использоваться из заранее приготовленных разработчиками (open, client, simple, closed) или же имя файла, из которого будут браться правила для firewall, если не подходит ни один из заранее приготовленных типов. Мы создадим файл ipfw.rules со своими собственными правилами, посему поставим firewall_type="/etc/ipfw.rules". Также необходим параметр firewall_quiet. Если его поставить в YES, то при загрузке будет отключен вывод на экран правил firewall. Однако для начала лучше ему дать значение NO, чтобы видеть активируемые правила при загрузке. Парметр firewall_logging установим в YES для того, чтобы велись логи. Поскольку у нас машина с двумя сетевыми картами и чтобы она вдруг не заработала как маршрутизатор поставим gateway_enable="NO" Итого, у нас получилась следующая вставка в rc.conf: firewall_enable="YES" firewall_script="/etc/rc.firewall" firewall_type="/etc/ipfw.rules" firewall_quiet="NO" firewall_logging="YES" gateway_enable="NO" 4. Настройка правил для Firewall. Создадим и отредактируем файл /etc/ipfw.rules, который мы указали в параметрах в rc.conf. Поскольку в конфиг ядра мы не добавляли параметр IPFIREWALL_DEFAULT_TO_ACCEPT, то ipfw по умолчанию не зависимо от наших настроек будет добавлять в конец правило 65535 deny ip from any to any. Поэтому мы должны разрешить все необходимые сервисы в нашем файле. Пусть у нас есть 2 интерфейса - xl0 и xl1. Для мостов приемлимым решением (а иногда и необходимым) является разрешение любого трафика на одном из интерфейсов и фильтрация входящего и исходящего на другом. Так и поступим - разрешим любой трафик на интерфейсе xl1, а фильтровать будем входящий на xl0. При работе моста есть еще одна особенность. Дело в том, что для корректной работы ip протокола необходимо использование протокола ARP. Если пакеты этого протокола не будут проходит через мост, то станции по разные стороны моста не смогут передавать друг другу пакеты, т.к. не будет выполняться преобразование ip-адресов в mac-адреса сетевых карт. ipfw имеет возможность ограничивать ethernet-протоколы. Для этого создается специальное правило для udp пакетов с адресом источника 0.0.0.0, а порт источника будет показывать номер ethernet-протокола. Таким образом можно заставить мост пропускать или не пропускать протоколы, отличные от IP. Для вышеупомянутого протокола arp правило будет выглядеть следующим образом: add allow udp from 0.0.0.0 2054 to 0.0.0.0 Поскольку мы решили помимо фильтрации также использовать traffic shaper dummynet, напишем правило, ограничивающее, например, весь проходящий icmp-трафик (входящий+исходящй) на 50Кб/с: add pipe 1 icmp from any to any pipe 1 config bw 50Kbit/s queue 10 Заметим, что в случае написания других правил для shaper'а, включающих в себя адресаузлов, сетей - их нужно ставить в самое начало нашего файла ipfw.rules. ipfw устроен таким образом, что пакет проверяется по правилам сверху вниз и как только находится правило, которому он удовлетворяет - проверка на соответствие другим нижестоящим правилам не производится. Таким образом, если пакет будет удовлетворять правилу фильтрации - он может не дойти до правил traffic shaper'а. Однако если первыми стоят правила шейпера, то существует возможность пропустить пакет по правилам, котрые стоят ниже правил шейпера. Для этого нужно установить переменную net.inet.ip.fw.one_pass=0. Добавим еще парочку правил, например, разрешающих прохождение входящего dns-трафика, обращений к web-серверу и icmp-трафика через интерфейс xl0. Также не забудем разрешить любой трафик через xl1: add 1000 allow tcp from any to any in via xl0 established add 1200 allow tcp from any to any domain in via xl0 add 1300 allow udp from any to any domain in via xl0 add 1400 allow udp from any domain to any 1024-65535 in via xl0 add 1500 allow tcp from any to any www in via xl0 add 1600 allow icmp from any to any add 1700 allow ip from any to any via xl1 Итого, наш итоговый файл /etc/ipfw.rules получился следующим: add pipe 1 icmp from any to any pipe 1 config bw 50Kbit/s queue 10 add 0900 allow udp from 0.0.0.0 2054 to 0.0.0.0 add 1000 allow tcp from any to any in via xl0 established add 1200 allow tcp from any to any domain in via xl0 add 1300 allow udp from any to any domain in via xl0 add 1400 allow udp from any domain to any 1024-65535 in via xl0 add 1500 allow tcp from any to any www in via xl0 add 1600 allow icmp from any to any add 1700 allow ip from any to any via xl1 5. Запуск моста с фильтрацией. Перезагрузимся, чтобы вступили в силу настройки rc.conf и загрузилось новое ядро. По умолчанию мост не работает. Для его запуска необходимо установить параметры net.link.ether.bridge_ipfw (чтобы работала фильтрация) и net.link.ether.bridge(чтобы активировать мост) в 1. Также необходимо для одновременной работы шейпера и фильтрации переменную net.inet.ip.fw.one_pass установить в 0. Сделаем это из приглашения командной строки: # sysctl -w net.inet.ip.fw.one_pass=0 # sysctl -w net.link.ether.bridge_ipfw=1 # sysctl -w net.link.ether.bridge=1 Все, мост работает. Для того, чтобы каждый раз после перезагрузки не надо было изменять значения переменных, добавим следующие строки в /etc/sysctl.conf (если нет такого файла - создайте его): net.inet.ip.fw.one_pass=0 net.link.ether.bridge_ipfw=1 net.link.ether.bridge=1 6. Производительность и несколько замечаний. Итак, мост готов. МЫ провели примерные замеры производительности. Конфигурация: PIII-500MHz, 128Mb RAM, 2 сетевых интерфейса 3COM 3C905B-TX, 3 очереди для шейпера + фильтр на 30 правил. Результаты получились следующими: задержка в 0.2 ms при отсутствии трафика и 0.8 ms при интенсивном обмене. Несколько замечаний по использованию мостов. Мосты не допускают создания архитектуры с петлями, поскольку в этом случае будет некорректно строится таблица соответствия моста. Если вы используете мост с фильтрацией, постарайтесь предусмотреть в правилах фильтра всё необходимое, иначе вы рискуете потратить много времени на поиск места, через которые не проходят нужные вам пакеты, особенно в больших сетях со сложной топологией. Мы также рекомендуем назначать на один из интерфейсов ip-адрес, чтобы иметь возможность настраивать его удаленно через ssh. И конечно, при использовании фильтрации, у вас должны быть открыты необходимые порты tcp для работы протокола ssh. Ссылки. - http://www.freebsd.org.ru/handbook/bridging.html - http://www.freebsd.org.ru/handbook/firewalls.html - http://info.iet.unipi.it/~luigi/ip_dummynet/ 7. Дополнения читателей Прислал Pavel V.Zheltobryukhov <[email protected]>: Родилось небольшое замечание - в список команд для запуска моста имхо стоит добавить согласно man sysctl -w net.link.ether.bridge_cfg=xl0:0,xl1:0 для перевода карт в promiscoius режим. (c) http://www.securityportal.ru , 2002г.

<< Предыдущая ИНДЕКС Поиск в статьях src Установить закладку Перейти на закладку Следующая >>

Обсуждение [ Линейный режим | Показать все | RSS ]
  • 1.1, доброжелатель (?), 03:03, 27/12/2003 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Из http://info.iet.unipi.it/~luigi/ip_dummynet/
    :
    sysctl -w net.inet.ip.fw.one_pass=0
    Forces a single pass through the firewall.
    If set to 0, packets coming out of a pipe will
    be reinjected into the firewall starting with
    the rule after the matching one.
    NOTE: there is always one pass for bridged packets.

    Стало быть для мостиков shaper+bridge не канает...
    И правда! По крайне мере до версии 4.8 так всё и есть, либо shaper, либо bridge.
    Как там у вас проводились "примерные замеры производительности" без "замеров" работоспособности для меня остаётся загадкой =)))

     
  • 1.2, доброжелатель (?), 03:22, 27/12/2003 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    ах да, незнаю как у Вас, а у меня дык с ARP'ом итак ффсё ништяк.
    Без фсяких ipfw add 1 allow udp from 0.0.0.0 2054 to 0.0.0.0 более того,
    с этим правилом у меня ВАЩЕ ни один пакет не совпал. ?!? странно =)))
     
     
  • 2.4, butcher (?), 10:09, 24/02/2004 [^] [^^] [^^^] [ответить]  
  • +/
    это фича работала до 4.4 включительно, дальше (говорю про 4.7) её убрали.. маны читать нужно..
     
     
  • 3.9, Spider (??), 21:31, 15/07/2005 [^] [^^] [^^^] [ответить]  
  • +/
    Как теперь фильтровать ETH?
     

  • 1.3, Aleksei (?), 22:07, 14/02/2004 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    interesno a mozno odnovremenno ispol'zovayt' most s marshrutizatorom, t.e. filtrovat' trafik dlja vneshnih IP provaidera i razdavat' inet po localke
     
  • 1.6, Spyshoper (?), 01:18, 29/02/2004 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    прошу ответить на
    вопрос. можно ли получить доступ(и как это настроить) по телнету к одному из
    интерфейсов в
    мосте одновременно из внешней и внутренней сети... просто у меня
    возникла ситуация когда люди из внутринней сети могут пинговать
    интерфейс(тот который с айпишником) а люди во внешней сети не могут.
     
  • 1.7, ALCOOL (?), 00:50, 25/05/2004 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    смотри правила ipfw - где-то вкралась ошибка. И telnet - плохо. Юзай ssh
     
  • 1.8, Nerian (?), 14:05, 05/09/2004 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    У меня тож такая проблема что истерфесй который с айпишником из внешней сети не пингуеться, в фаерволе я использую следующее правило:
    ipfw -q add 1000 allow from any to any
    Что можно сделать?
     
  • 1.10, Halt (ok), 15:15, 10/10/2005 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Handbook forever
    пока не прописал в sysctl.conf:
    net.link.ether.bridge_cfg=if1,if2
    не заработало.
     
  • 1.11, SekaTOP (??), 15:34, 13/10/2005 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Вопрос: Можно ли на мосту создать статическую ARP таблицу привязки IP к MAC, чтобы непрописанные в ней юзеры не могли "пробиться" дальше моста.
     
     
  • 2.12, _Nick_ (??), 21:24, 13/10/2005 [^] [^^] [^^^] [ответить]  
  • +/
    >Вопрос: Можно ли на мосту создать статическую ARP таблицу привязки IP к
    >MAC, чтобы непрописанные в ней юзеры не могли "пробиться" дальше моста.
    >

    вырубаешь ARP на интерфейсе и прописываешь статику.
    Все. Танки не пройдут.

     
     
  • 3.13, SekaTOP (??), 11:39, 14/10/2005 [^] [^^] [^^^] [ответить]  
  • +/
    это и ежу понятно. Но в этом случае придется на клиентских машинах прописывать шлюзом IP интерфейса моста (хотя мост вполне может работать и без поднятого интерфейса), а на самом мосту прописывать gateway и запрещать доступ к нему в ipfw. В этом случае проще сразу поднимать роутер, а это сделать проблематично, т.к. нарушится структура действующей сети.
    Необходимо на мосту сделать привязку клиетских IP к MAC и несоответствующие адреса не пускать дальше моста.
    Есть идеи?
     
     
  • 4.14, _Nick_ (??), 19:50, 14/10/2005 [^] [^^] [^^^] [ответить]  
  • +/
    ok SekaTOP,

    если серьезно, то сходу - ARPtables в Линухе.
    Бздю я зыбыл 2 года назад, но ARPtables не пришлось попробовать.

    Хочешь - поковыряй. Нет - я в саду %)

     

  • 1.15, Yukka (?), 20:30, 06/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    А как завернуть проходящий траффик на прокси?
     
     
  • 2.16, LM (??), 09:23, 08/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >А как завернуть проходящий траффик на прокси?

    google: squid transparent proxy

    То что тебе надо назваеться прозрачный прокси

     

  • 1.17, Yukka (?), 12:42, 10/09/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Все бы были такими умными. Во ФрееБСД в режиме бриджа не работает  ни ipfw divert ни ipfw forward. А теперь повторюсь:

     
     
  • 2.18, Yukka (?), 12:46, 10/09/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Все бы были такими умными. Во ФрееБСД в режиме бриджа не работает
    > ни ipfw divert ни ipfw forward. А теперь повторюсь:

    Как в режиме бриджа завернуть трафик на прокси?

     

  • 1.19, Wedmed (?), 13:49, 22/01/2008 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    в FreeBSD 6.2 команда
    # sysctl -w net.link.ether.bridge=1
    выдает ошибку
    net.link.ether.bridge isn't a leaf node
    вместо нее сейчас видимо
    # sysctl -w net.link.ether.bridge.enable=1
     

    игнорирование участников | лог модерирования

     Добавить комментарий
    Имя:
    E-Mail:
    Заголовок:
    Текст:




    Партнёры:
    PostgresPro
    Inferno Solutions
    Hosting by Hoster.ru
    Хостинг:

    Закладки на сайте
    Проследить за страницей
    Created 1996-2025 by Maxim Chirkov
    Добавить, Поддержать, Вебмастеру