Следующая версия | Предыдущая версия |
dpi:bras_bng:bras_pppoe:pppol2tp_conf [2025/09/29 15:01] – создано elena.krasnobryzh | dpi:bras_bng:bras_pppoe:pppol2tp_conf [2025/09/29 16:13] (текущий) – elena.krasnobryzh |
---|
{{indexmenu_n>4}} | {{indexmenu_n>4}} |
======Настройка PPPoL2TP и команды====== | ======Настройка PPPoL2TP и команды====== |
| L2TP (Layer 2 Tunneling Protocol) — протокол для туннелирования трафика уровня 2 через сеть уровня 3. L2TP используется для обеспечения туннелирования протокола PPP (Point-to-Point Protocol, «точка-точка») в вашей сети. |
| |
| Для работы L2TP требуется LAC (L2TP access concentrator, концентратор доступа L2TP) и LNS (L2TP network server, сетевой сервер L2TP). LNS является одной из конечных точек туннеля L2TP. LAC, настроенный на устройстве доступа, получает пакеты от удаленного клиента и пересылает их на LNS в удаленной сети. LAC и LNS являются одноранговыми. |
| |
| Особенности реализации: |
| - Поддерживается L2TPv2 |
| - Так как абонент выступает в роли концентратора (LAC), то между абонентом и LNS (L2TP-сервером СКАТ) устанавливается один туннель, в нем ровно одна PPP сессия. |
| - Транспорт для L2TP - только IPv4 (IPv6 не планируется) |
| - При установке L2TP-соединения (туннеля) никакой авторизации не требуется: BRAS LNS устанавливает L2TP туннель с любым инициатором; для установки L2TP туннеля инициатор (в роли LAC) не использует пароль, BRAS не проверяет имя инициатора и не требует пароль для L2TP туннеля. |
| |
| С точки зрения BRAS, есть два типа L2TP абонентов. Абонентам выдан IP локального BRAS для установки L2TP: |
| - Абонент PPPoL2TP получает IP-адрес по DHCP на текущем BRAS и поднимает L2TP с текущим BRAS.\\ {{:dpi:bras_bng:bras_pppoe:pppol2tp_conf_1.png?nolink&600|}} |
| - Абонент PPPoL2TP получает IP-адрес по DHCP на удаленном BRAS и поднимает L2TP с текущим BRAS.\\ {{:dpi:bras_bng:bras_pppoe:pppol2tp_conf_2.png?nolink&600|}} |
| |
| **Параметры:** |
| ^ Параметр ^ Описание ^ Значение по умолчанию и возможные значения ^ |
| | ''bras_l2tp_enable'' | Включение функциональности BRAS L2TP (PPPoL2TP). Примечание: опция ''bras_enable'' должна быть включена. Требует перезапуска | | |
| | ''bras_l2tp_max_retransmit'' | Максимальное число ретрансмитов CTL-сообщений (RFC 2661 p.5.8). Если не получили подтверждения приема ни на один ретрансмит — туннель закрывается (как неактивный). \\ Не требует перезапуска | Значение по умолчанию — 5 | |
| | ''bras_l2tp_mru'' | Максимальный размер PPP-пакета, инкапсулированного в L2TP. Если для L2TP-сервера явно не задан MTU — используется значение опции ''bras_l2tp_mru''.\\ :!: Параметр может настраиваться на уровне LNS сервера через CLI | Значение по умолчанию — 1460 | |
| | ''bras_l2tp_ratelimit'' | Контроль количества запросов от абонента на открытие L2TP-туннеля/сессии в секунду (предотвращение L2TP-спама). \\ Не требует перезапуска | 0 — контроль отключен (значение по умолчанию) | |
| | ''bras_l2tp_ratelimit_ban'' | Время бана абонента при превышении ''bras_l2tp_ratelimit'', в секундах. \\ Не требует перезапуска | При включенном режиме контроля bras_l2tp_ratelimit (bras_l2tp_ratelimit != 0) этот параметр должен быть задан отличным от 0 | |
| | ''bras_l2tp_min_lifetime'' | Минимальное время жизни туннеля, секунд. Абонент может создавать новые туннели не чаще, чем раз в ''bras_l2tp_min_lifetime'' секунд (защита от спама). \\ Не требует перезапуска | Значение по умолчанию: 2\\ 0 — без ограничений | |
| | ''bras_l2tp_default_vrf'' | Имя VRF по умолчанию, в котором анонсируются L2TP-сервера. VRF может быть задана индивидуально для каждого L2TP-сервера. Если для сервера явно не задан VRF — используется VRF, заданный в этой опции. \\ Не требует перезапуска.\\ :!: Параметр может настраиваться на уровне LNS сервера через CLI | | |
| | ''ajb_save_ip'' | Запись L2TP-пакетов в pcap задается параметром ajb_save_ip. В нем можно указать:\\ - IP-адрес абонента для L2TP-туннеля, будет записываться весь трафик для данного абонента;\\ - IP-адрес L2TP-сервера: в этом случае в pcap будет записываться весь обмен данными с этим сервером.\\ Подробнее про параметр в разделе [[dpi:bras_bng:cli:bras_l2_vlan_trace]]\\ :!: Параметр может настраиваться на уровне LNS сервера через CLI | | |
| | ''allowed-mark'' | Добавлена возможность указывать, для каких подсетей можно создавать L2TP-туннели. Как обычно, подсети указываются через AS (файлы ''aslocal.bin'' и ''asnum.dscp''); среди флагов AS разрешено только ''mark3''.\\ В свойствах L2TP-сервера с помощью параметра ''allowed-mark'' указывается номер флага (''1'', ''2'' или ''3''), который будет признаком разрешения устанавливать L2TP-туннели для этой AS. Пример задания флага AS ''mark2'': \\ l2tp server modify 78.107.11.103 allowed-mark=2\\ По умолчанию, у LNS нет свойства allowed-mark, то есть разрешено создавать туннели для всех IP. Чтобы удалить у LNS свойство allowed-mark, нужно указать allowed-mark=0: \\ ''l2tp server modify 78.107.11.103 allowed-mark=0''\\ После этого данный L2TP-сервер будет создавать туннели для любого абонента.\\ То есть общий алгоритм указания ACL для LNS-сервера таков:\\ 1. Выбираем флаг ''mark3'', который мы будем использовать как метку ACL. Используется только флаг ''mark3'' во избежание коллизии с маркировкой для других целей\\ 2. Помечаем в ''asnum.dscp'' автономные системы для разрешенных подсетей этим флагом (см. [[dpi:bras_bng:general_setup]])\\ 3. CLI-командой задаем LNS-серверу свойство ''allowed-mark'', равное номеру флага\\ \\ :!: Параметр может настраиваться на уровне LNS сервера через CLI | | |
| |
| **CLI-команды:** |
| ^ Команда ^ Описание ^ |
| | ''l2tp server add IP <props>'' | Добавление нового L2TP-сервера | |
| | ''l2tp server modify IP <props>'' | Изменение свойств уже заданного L2TP-сервера | |
| | ''l2tp server delete IP'' | Удаление L2TP-сервера | |
| | ''l2tp show [all|IP]'' | Просмотр свойств L2TP-серверов | |
| | ''l2tp stat [all|IP]'' | Просмотр статистики L2TP-серверов | |
| | ''l2tp term'' | Закрытие всех L2TP-сессий. Есть возможность указать параметры ''ip'', ''mac'', ''subs_id'', ''login'' или ''all'':\\ ''l2tp term [hard] [ip=X | mac=X | subs_id=X | login=X | all]'' | |
| |
| =====Статистика LNS===== |
| Вывести статистику: |
| <code bash>fdpi_cli l2tp server stat <IP></code> |
| |
| Пример вывода: |
| <code bash> |
| invalid session type: 0 |
| session not found: 13 |
| bad L2TP version: 0 |
| malformed ctl packet: 0 |
| too complex packet: 0 |
| unknown mandatory attr: 0 |
| unsupported ctl message: 0 |
| unexpected ctl message: 2 |
| out of order: 0 |
| window size exceeded: 0 |
| too many unconfirmed msg: 0 |
| subs IP/tid/sid mismatch: 0 |
| malformed data packet: 0 |
| too frequent SCCRQ: 0 |
| rate-limit ban: 0 |
| AS access denied: 0 |
| MTU exhausted: 0 |
| ctl retransmit exhausted: 0 |
| FSM violation: 0 |
| TOTAL: 15 |
| </code> |
| |
| Описание параметров вывода: |
| - ''invalid session type'' — Найденная в PPP DB по l2subs_id сессия не является L2TP-сессией |
| - ''session not found'' — Сессия не найдена в PPP DB по l2subs_id |
| - ''bad L2TP version'' — Неподдерживаемая версия L2TP |
| - ''malformed ctl packet'' — Ошибочный ctl-пакет (не соответствует RFC) |
| - ''too complex packet'' — Слишком сложный пакет - слишком много атрибутов |
| - ''unknown mandatory attr'' — Неизвестный обязательный атрибут |
| - ''unsupported ctl message'' — Неподдерживаемый ctl-пакет |
| - ''unexpected ctl message'' — В текущем состоянии ctl-пакет не поддерживается |
| - ''out of order'' — Нарушен порядок ctl-пакетов |
| - ''window size exceeded'' — Нарушение размера нашего окна |
| - ''too many unconfirmed msg'' — Слишком много неподтвержденных ctl msg у сессии |
| - ''subs IP/tid/sid mismatch'' — Ошибка: IP абонента, или L2TP tunnel/session is не совпадает с теми, что запомнены в сессии |
| - ''malformed data packet'' — Ошибочный data-пакет |
| - ''too frequent SCCRQ'' — Слишком частое пересоздание L2TP-туннеля |
| - ''rate-limit ban'' — Превышение ratelimit |
| - ''AS access denied'' — Запрет создания L2TP-сессий для подсети (=> для AS) |
| - ''MTU exhausted'' — Превышение MTU (snaplen) при поступлении пакета на обработку |
| - ''ctl retransmit exhausted'' — Число закрытых сессий из-за исчерпания ретрансмитов ctl-сообщений |
| - ''FSM violation'' — Нарушение state machine |
| |