Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    Исходящий трафик с определённого хоста лl

    Scheduled Pinned Locked Moved Russian
    22 Posts 4 Posters 8.0k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • D
      DasTieRR
      last edited by

      @strio911:

      В Firewall rules на ЛАН создаем правило, разрешающее хосту ходить в инет. Надеюсь про порядок правил помним.

      Помним ;D

      в правиле гейтвеем указываем ип ОПТа. Это называется PolicyBased routing - то есть правило с маршрутом.

      А вот здесь как выбрать именно интерфейс с которого будем ходить? У меня оба внешних IP из одной подсети и естественно у них один и тот-же шлюз (111.111.111.110/29)
      и при создании этого самого правила в выпадающем списке выдаёт просто мне default, 111.111.111.110, 111.111.111.110, т.е. для по шлюзу для каждого интерфейса, а они одинаковые..

      Вот так, выделенное жирным шрифтом и показывает? Поставьте один из них, вытащите один из кабелей wan или opt1 и будет понятно, какой шлюз использует нужный комп.

      1 Reply Last reply Reply Quote 0
      • D
        dvserg
        last edited by

        @DasTieRR:

        @strio911:

        В Firewall rules на ЛАН создаем правило, разрешающее хосту ходить в инет. Надеюсь про порядок правил помним.

        Помним ;D

        в правиле гейтвеем указываем ип ОПТа. Это называется PolicyBased routing - то есть правило с маршрутом.

        А вот здесь как выбрать именно интерфейс с которого будем ходить? У меня оба внешних IP из одной подсети и естественно у них один и тот-же шлюз (111.111.111.110/29)
        и при создании этого самого правила в выпадающем списке выдаёт просто мне default, 111.111.111.110, 111.111.111.110, т.е. для по шлюзу для каждого интерфейса, а они одинаковые..

        Вот так, выделенное жирным шрифтом и показывает? Поставьте один из них, вытащите один из кабелей wan или opt1 и будет понятно, какой шлюз использует нужный комп.

        Лучше поставить и правила посмотреть. Если там на интерфейсах все сделано - то должно работать.
        Правила в /tmp/rules.debug

        ПС У меня гейтвей ОПТа последним стоит

        SquidGuardDoc EN  RU Tutorial
        Localization ru_PFSense

        1 Reply Last reply Reply Quote 0
        • D
          DasTieRR
          last edited by

          Люблю подстраховаться… с кабелем оно наверняка :)))

          1 Reply Last reply Reply Quote 0
          • S
            strio911
            last edited by

            ПС У меня гейтвей ОПТа последним стоит

            У меня тоже.

            Создал правило: написал для проверки, что если адрес соурса 10.10.10.11 и порт назначения 80, то ходить через указанный шлюз (OPT)
            cat /tmp/rules.debug

            User-defined rules follow

            pass in quick on $lan proto tcp from {  10.10.10.11 }  to <vpns>port = 80 keep state  label "NEGATE_ROUTE: Negate policy route for local network(s)"
            pass in quick on $lan  route-to ( xl0 111.111.111.110 ) proto tcp from {  10.10.10.11 } to any port = 80 keep state  label "USER_RULE"
            pass in quick on $lan from 10.10.10.0/24 to any keep state  label "USER_RULE: Default LAN -> any"

            зашёл для проверки на getip.ру. Как и ожидал показывает IP моего ван интерфейса.

            На всякий случай указал и другой (такой же шлюз в выпадающем меню) эффект такой-же.</vpns>

            1 Reply Last reply Reply Quote 0
            • D
              dvserg
              last edited by

              А кабель выдернуть ?  ::)

              SquidGuardDoc EN  RU Tutorial
              Localization ru_PFSense

              1 Reply Last reply Reply Quote 0
              • D
                DasTieRR
                last edited by

                @strio911:

                ПС У меня гейтвей ОПТа последним стоит

                У меня тоже.

                Создал правило: написал для проверки, что если адрес соурса 10.10.10.11 и порт назначения 80, то ходить через указанный шлюз (OPT)
                cat /tmp/rules.debug

                User-defined rules follow

                pass in quick on $lan proto tcp from {  10.10.10.11 }  to <vpns>port = 80 keep state  label "NEGATE_ROUTE: Negate policy route for local network(s)"
                pass in quick on $lan  route-to ( xl0 111.111.111.110 ) proto tcp from {  10.10.10.11 } to any port = 80 keep state  label "USER_RULE"
                pass in quick on $lan from 10.10.10.0/24 to any keep state  label "USER_RULE: Default LAN -> any"

                зашёл для проверки на getip.ру. Как и ожидал показывает IP моего ван интерфейса.

                На всякий случай указал и другой (такой же шлюз в выпадающем меню) эффект такой-же.</vpns>

                Для ICMP тоже сделай правило.
                я не думаю, что он через 80 порт IP узнаёт (могу ошибаться)

                1 Reply Last reply Reply Quote 0
                • S
                  strio911
                  last edited by

                  А кабель выдернуть ?

                  Да я попробовал бы =), только во первых: не пойму зачем, во вторых я сейчас не рядом с файрволом, я по ВПН.
                  А просто OPT отключить через вебморду не пойдёт?

                  Для ICMP тоже сделай правило.
                  не думаю, что он через 80 порт IP узнаёт (могу ошибаться)

                  Не поможет.

                  Вобщем поступил так:

                  в файле /tmp/rules.debug

                  нашёл строку в которой создано "неправильное" правило

                  pass in quick on $lan  route-to ( xl0 111.111.111.110 ) proto tcp from {  10.10.10.11 } to any port = 80 keep state  label "USER_RULE"

                  • жирным это WAN;
                    Заменил название интерфейса на нужное мне (2-ой WAN)
                    pass in quick on $lan  route-to ( rl0 111.111.111.110 ) proto tcp from {  10.10.10.11 } to any port = 80 keep state  label "USER_RULE"

                  после чего сделал pfctl -f /tmp/rules.debug …

                  И всё заработало  :D

                  Но теперь другая проблема, как сделать чтобы это правило на постоянку "прилипло". ведь после перезагрузки файл с правилами генерируется заново из XML-файла конфигурации.
                  В XML пробывал посмотреть, но там описание этого правила имеет несколько другой вид:
                  <rule><type>pass</type>
                  <interface>lan</interface>
                  <max-src-nodes><max-src-states><statetimeout><statetype>keep state</statetype>
                  <os><protocol>tcp</protocol>
                  <source>

                  <address>10.10.10.11</address>

                  <destination><any><port>80</port></any></destination>
                  <descr><gateway>111.111.111.110</gateway></descr></os></statetimeout></max-src-states></max-src-nodes></rule>

                  Как в этой секции, отвечающей за генерацию нужно мне правила, указать, что интерфейс для выхода rl0 ???
                  Добавление <interface>opt1</interface> перед <gateway>111.111.111.110</gateway> не помогает (при парсинге XML выдается ошибка)

                  1 Reply Last reply Reply Quote 0
                  • D
                    dvserg
                    last edited by

                    Я думаю это недоработка или особенность - ищет интерфейс по гейтвею.
                    Если у Евгения есть время - посмотреть сорцы на этот счет и пообщаться с разрабами.

                    SquidGuardDoc EN  RU Tutorial
                    Localization ru_PFSense

                    1 Reply Last reply Reply Quote 0
                    • E
                      Eugene
                      last edited by

                      Возможно тупой вопрос, но - если линк от провайдера один, то зачем два интерфейса WAN и OPT-WAN? Почему бы не сделать один WAN с виртуальными адресами? а там уж рути/нать трафик как хочешь… Чего-то я вас не догоняю сутра, братцы -(

                      http://ru.doc.pfsense.org

                      1 Reply Last reply Reply Quote 0
                      • E
                        Eugene
                        last edited by

                        Да… и Евгений перешёл на другую работу, абсолютно никак несвязанную с pfSense, посему наверное скоро скажет проекту "до свидания" -(

                        http://ru.doc.pfsense.org

                        1 Reply Last reply Reply Quote 0
                        • S
                          strio911
                          last edited by

                          один WAN с виртуальными адресами?

                          А чем это поможет? Ведь у меня от этого у меня не появиться возможность на основе PolicyBased routing перенаправлять исходящий трафик через нужный мне интерфейс.

                          1 Reply Last reply Reply Quote 0
                          • E
                            Eugene
                            last edited by

                            @strio911:

                            один WAN с виртуальными адресами?

                            А чем это поможет? Ведь у меня от этого у меня не появиться возможность на основе PolicyBased routing перенаправлять исходящий трафик через нужный мне интерфейс.

                            Если задача - перенаправлять через нужный интерфейс, то - нет, не появится, т.к. этот интерфейс перестанет существовать. Если задача - перенаправлять через/с нужный IP, то всё решится.
                            Если не секрет - зачем через отдельный интерфейс если всё равно к одному провайдерскому шлюзу?

                            http://ru.doc.pfsense.org

                            1 Reply Last reply Reply Quote 0
                            • S
                              strio911
                              last edited by

                              Если задача - перенаправлять через/с нужный IP, то всё решится.

                              Да в принципе на данный момент именно такая задача. Но как это сделать что-то не приложу ума как.

                              зачем через отдельный интерфейс если всё равно к одному провайдерскому шлюзу?

                              Просто так исторически сложилось (были/осталась задумки).

                              1 Reply Last reply Reply Quote 0
                              • E
                                Eugene
                                last edited by

                                @strio911:

                                Если задача - перенаправлять через/с нужный IP, то всё решится.

                                Да в принципе на данный момент именно такая задача. Но как это сделать что-то не приложу ума как.

                                Один WAN c 111.111.111.111/29.
                                На WAN создаёшь Proxy-ARP виртуальный IP 111.111.111.112.
                                Далее трафик с хоста 10.10.10.11/32 в OutboundNAT делаешь натить используя 111.111.111.112, а трафик с 10.10.10.0/24  - используя 111.111.111.111 (порядок правил должен быть именно такой). Всё собственно.

                                http://ru.doc.pfsense.org

                                1 Reply Last reply Reply Quote 0
                                • S
                                  strio911
                                  last edited by

                                  Евгений, спасибо!  :)
                                  Этот рецепт помог.

                                  Только вот:

                                  Я думаю это недоработка или особенность - ищет интерфейс по гейтвею.
                                  Если у Евгения есть время - посмотреть сорцы на этот счет и пообщаться с разрабами.

                                  Если всё-таки будет вариант "попинать" девелоперов было бы неплохо реализовать именно как я понял. Чтобы выбор шлюза ещё соответствовал интерфейсу.
                                  В данный момент такой нужды нет, но теоретически такая фенечка была бы очень кстати (хотя скорее всего только для моих сверхмаразматичных задач ::) ).

                                  Ещё раз спасибо. (Решено)

                                  1 Reply Last reply Reply Quote 0
                                  • D
                                    dvserg
                                    last edited by

                                    Сначала нужно на 2.0 проверить. Ветку 1.2 думаю уже никто копать не будет.

                                    SquidGuardDoc EN  RU Tutorial
                                    Localization ru_PFSense

                                    1 Reply Last reply Reply Quote 0
                                    • First post
                                      Last post
                                    Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.