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

    Странный рутинг

    Scheduled Pinned Locked Moved Russian
    36 Posts 7 Posters 13.3k 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.
    • R
      rubic
      last edited by

      Я бы попросил вас неприличными словами тут не выражаться) По сути вопроса, маршруты, в том виде как вы их заводите, работают у тысяч и сотен тысяч пользователей pfSense. Единственное, что следует учитывать - это policy routing. Правилами Firewall -> Rules можно переназначить gateway и это переназначение будет иметь приоритет над таблицей маршрутизации.
      Если у вас policy routing'а нет, то все должно работать. Все вы сделали правильно.

      1 Reply Last reply Reply Quote 0
      • C
        chawoosh
        last edited by

        Именно это я имел в виду. Такие правила работают на линуксе, FreeBSD и даже винде (извините за повтор), а здесь ядро просто игнорирует частное правило и сразу шлёт пакеты по дефолтному.
        Ещё раз повторюсь: правилами Firewall -> Rules невозможно назначить маршрут куда-то налево, не введя понятие ещё одного гейта. Правильно? Именно так в конечном счёте и было проделано, был опрелён доп. гейт, в него прописан маршрут, отправлять туда пакеты назначенные в "левую" сеть. В результате в таблице рутинга появляется тоно такая же запись, как при определении маршрута командой route add (специально смотрел), и результат совершенно аналогичный. Т.е. либо всё же бага в ядре в 2.0.1, либо где-то сидит здоровенный побочный эффект.
        То, что я "всё сделал правильно" - не утешает ;)

        1 Reply Last reply Reply Quote 0
        • R
          rubic
          last edited by

          Все это странно конечно, при том, что у меня например такие маршруты не первый год нормально работают. Одно скажу, ядро тут не при чем.
          Пара мыслей. Маршруты нужно определять не через Firewall -> Rules, а через System -> Routing вкладка Routes. Тогда они будут действительны не только для машин за pfSense, но и для самого pfSense. Иначе трассировка с pfSense даст то, что вы и наблюдаете.
          Отзывается ли сервер OpenVPN на пинг с pfSense? Если нет, то определенный вами gateway может расценен как недоступный. Проверьте это в Status -> Gateways.

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

            @rubic:

            Пара мыслей. Маршруты нужно определять не через Firewall -> Rules, а через System -> Routing вкладка Routes.

            Такие маршруты будут действительны только для самого pfSense. А станции в сети - по правилам FW Rules отдельно работают.

            Я уже нарывался на такое, отписывался здесь в какой-то теме.

            1 Reply Last reply Reply Quote 0
            • C
              chawoosh
              last edited by

              Вот это уже интересно, нужно попробовать.
              Гейт/сервер vpn естественно пингуется и с базовой машины и из pfSense.

              1 Reply Last reply Reply Quote 0
              • R
                rubic
                last edited by

                @sweep4:

                @rubic:

                Пара мыслей. Маршруты нужно определять не через Firewall -> Rules, а через System -> Routing вкладка Routes.

                Такие маршруты будут действительны только для самого pfSense. А станции в сети - по правилам FW Rules отдельно работают.

                Я уже нарывался на такое, отписывался здесь в какой-то теме.

                Эти маршруты будут действительны для всех, если иное не определено в Firewall -> Rules. Иными словами, если в правиле Firewall -> Rules gateway выставлен как default, то будет действовать таблица маршрутизации pfSense, включая то, что пользователь прописал в System -> Routing [Routes].
                Если вы хотите чтобы для определенного трафика действовала дефолтная таблица маршрутов, то правило для этого трафика в Firewall -> Rules нужно поставить выше правил, для которых определен альтернативный gateway и под которые подпадает этот трафикю

                1 Reply Last reply Reply Quote 0
                • C
                  chawoosh
                  last edited by

                  Прекрасный пример ответа "вообще", не читая вопроса. :)

                  В общем, только после того как прописал особое правило рутинга во "Floating rules", появился контакт к хостам подключенным через OpenVPN сервер (выделенный).

                  1 Reply Last reply Reply Quote 0
                  • C
                    chawoosh
                    last edited by

                    Мда, чудны дела твои…
                    Поторопился малость. Из машин за гейтом контакт с машинами в OpenVPN есть, а вот если попытаться из VPN подключиться к машине за pfSense, облом. Т.е. пакеты от источника до получателя доходят, тот отвечает, естественно на адреса отправителя, но на сервер VPN эти пакеты не попадают... Загадка. Подключение от машин, находящихся просто в одной сети с выходным интерфейсом pfSense, проходит без сучка и задоринки. Будем смотреть теперь физический интерфейс :)

                    1 Reply Last reply Reply Quote 0
                    • R
                      rubic
                      last edited by

                      У вас cisco - это то, куда все сходится, и для всех она default gateway. Вот на ней я бы на вашем месте и прописал маршрут в 10.8.0.0/24 через 192.168.21.214, а если NAT на pfSense отключен, то и в сети 192.168.0.0/24, 192.168.1.0/24 через WAN IP pfSense. Да, трафик между машинами за pfSense и клиентской сетью OpenVPN ходил бы через cisco, но если он небольшой, то и нормально. Зато весь ручной роутинг в одном месте.
                      Еще у pfSense есть такой момент, что пакеты от локальных процессов всегда уходят через default gateway. Я к тому, что трассировка с самого pfSense - не показатель, нужно трассировать 10.8.0.0/24 с машины за pfSense. То, что вы прописали floating rule исправило только этот момент. По сути это правило для общения машин за pfSense с клиентской сетью OpenVPN не нужно, достаточно маршрута в System -> Routing -> Routes

                      1 Reply Last reply Reply Quote 0
                      • C
                        chawoosh
                        last edited by

                        теоретически оно может и так, а практически правило в System -> Routing -> Routes эффекта не даёт, что без "плавающего правила", что с ним. NAT естественно включен, с одной стороны у pfSense сеть .21.0/24, с другой - .0.0/24.

                        Чуть позже: таки пришлось прописать правило во внутреннем рутере, который виланами рулит и является гейтом для всех. Странновато реализован рутинг в pfSense, при том что это вообще-то рутер по призванию.

                        1 Reply Last reply Reply Quote 0
                        • A
                          aleksvolgin
                          last edited by

                          это вообще-то рутер по призванию.

                          Нее. По призванию он как раз кусок роутера. А полноценный роутер из него как раз хотят все сделать. Ожидаемо безуспешно.

                          1 Reply Last reply Reply Quote 0
                          • R
                            rubic
                            last edited by

                            @chawoosh:

                            NAT естественно включен, с одной стороны у pfSense сеть .21.0/24, с другой - .0.0/24.

                            Да? И в чем взаимосвязь?

                            Странновато реализован рутинг в pfSense, при том что это вообще-то рутер по призванию.

                            Не надо делать глобальных выводов из вашей частной неудачи. Не то превратитесь в "обиженного", такого как постом выше. Вы очевидно недавно на pfSense, решили сделать все по наитию, не прочитав документацию. Где-то накосячили в конфигурации и не видите этого. Схему сети выкладывать не хотите, скриншоты очевидно тоже. Ну, вал_и_те теперь все на pfSense, это действительно проще чем признать, что чего-то не понимаете.
                            Ваша ситуация (асимметричный роутинг) яйца выеденного не стоит и элементарно решается. Будет схема, будут скрины, будем говорить.

                            1 Reply Last reply Reply Quote 0
                            • A
                              aleksvolgin
                              last edited by

                              2 rubic

                              Не то превратитесь в "обиженного", такого как постом выше.

                              Это не обида, это констатация очевидного факта. Концепцию нужно менять. Она себя исчерпала уже в m0n0. Из куска маршрутизатора полноценный роутер не получиться, очевидно-же.

                              1 Reply Last reply Reply Quote 0
                              • C
                                chawoosh
                                last edited by

                                Специально для великого Рубика приведу невообразимо сложную схему

                                Из подписей и предидущих постов вроде должно быть ясно что и куда должно бегать. Единственное пояснение - pfSense и Hosts array - внутри ESXi 5.

                                NAT естественно включен, с одной стороны у pfSense сеть .21.0/24, с другой - .0.0/24.

                                Да? И в чем взаимосвязь?

                                Может великий подскажет способ общения компов, находящихся в разных сетях, в обе стороны, не применяя NAT. Нобелевскую не дадут, но на что-то поменьше можно рассчитывать.

                                1 Reply Last reply Reply Quote 0
                                • werterW
                                  werter
                                  last edited by

                                  @chawoosh:

                                  Может великий подскажет способ общения компов, находящихся в разных сетях, в обе стороны, не применяя NAT. Нобелевскую не дадут, но на что-то поменьше можно рассчитывать.

                                  У меня так две локальные сети и "общаются" (10.7.0.х и 10.7.1.х), хотя на внешних интерфейсах обеих  - адреса 192.168.0.х. И в обеих сетях в логах на pf-ах я "вижу" статистику от узлов 10.7.0.х\10.7.1.х, а не от 192.168.х.х. Само собой в правилах NAT-а стоит "галка" на No NAT. Так уж у нас повелось и такие корпоративные требования и требования пров-ра, к-ый предоставляет канал для связи эти двух сетей.

                                  Вопрос - ЧЯДНТ ?

                                  1 Reply Last reply Reply Quote 0
                                  • C
                                    chawoosh
                                    last edited by

                                    Где вы нашли провайдера, который вам даёт левонетовские адреса?
                                    Если у вас десятые сети прописаны как /8 или хотя бы как /16, то ничего удивительного.

                                    1 Reply Last reply Reply Quote 0
                                    • werterW
                                      werter
                                      last edited by

                                      @chawoosh:

                                      Где вы нашли провайдера, который вам даёт левонетовские адреса?
                                      Если у вас десятые сети прописаны как /8 или хотя бы как /16, то ничего удивительного.

                                      Нам корпоративный канал пров предоставляет внутри своей сети (vlan-ом). И да , когда на WAN - Инет, то без NAT-а никуда.
                                      Просто не стоит однозначно утверждать , что без трансляции адресов невозможно функционирование сетей.
                                      Мой пример - как частный случай такой возможности.

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

                                        @werter:

                                        @chawoosh:

                                        Где вы нашли провайдера, который вам даёт левонетовские адреса?
                                        Если у вас десятые сети прописаны как /8 или хотя бы как /16, то ничего удивительного.

                                        Нам корпоративный канал пров предоставляет внутри своей сети (vlan-ом). И да , когда на WAN - Инет, то без NAT-а никуда.
                                        Просто не стоит однозначно утверждать , что без трансляции адресов невозможно функционирование сетей.
                                        Мой пример - как частный случай такой возможности.

                                        У нас провайдер с белым адресом канал выделяет, а маршрутизация с помощью BGP сделана без NATа. VLAN-ов нет, по крайней мере на нашей стороне.
                                        Одно время на этом канале с успехом работал PFSense с пакетом BGP.

                                        SquidGuardDoc EN  RU Tutorial
                                        Localization ru_PFSense

                                        1 Reply Last reply Reply Quote 0
                                        • C
                                          chawoosh
                                          last edited by

                                          Да, снимаю своё утверждение про NAT, как сказанное в запале. В данном случае NAT'ом изолирован зоопарк внутри вмварного сервера от корпоративной сети.

                                          У нас провайдер с белым адресом канал выделяет, а маршрутизация с помощью BGP сделана без NATа. VLAN-ов нет, по крайней мере на нашей стороне.
                                          Одно время на этом канале с успехом работал PFSense с пакетом BGP.

                                          Если у вас внутри сети - белые адреса (трансляция 1:1), то NAT естественно не нужен. Если левонет - обязан наличествовать, т.к. в И-нете левонет не живёт. BGP занимается маршрутизацией между автономными системами (в основном) и к преобразованию адресов никакого отношения не имеет.

                                          1 Reply Last reply Reply Quote 0
                                          • R
                                            rubic
                                            last edited by

                                            Давайте для начала скриншоты

                                            1. System -> Routing -> Gateways, Routes и Groups (если не пусто)
                                            2. Firewall -> Rules по всем вкладкам
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.