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 являются одноранговыми.
Особенности реализации:
С точки зрения BRAS, есть два типа L2TP абонентов. Абонентам выдан IP локального BRAS для установки L2TP:


Параметры:
| Параметр | Описание | Значение по умолчанию и возможные значения |
|---|---|---|
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. | Значение по умолчанию — 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, заданный в этой опции. Не требует перезапуска. | |
ajb_save_ip | Запись L2TP-пакетов в pcap задается параметром ajb_save_ip. В нем можно указать: - IP-адрес абонента для L2TP-туннеля, будет записываться весь трафик для данного абонента; - IP-адрес L2TP-сервера: в этом случае в pcap будет записываться весь обмен данными с этим сервером. Подробнее про параметр в разделе Трассировка fastDPI BRAS L2 | |
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 автономные системы для разрешенных подсетей этим флагом (см. Общая настройка BRAS для L2/L3 режимов)3. CLI-командой задаем LNS-серверу свойство allowed-mark, равное номеру флага |
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] |
Вывести статистику:
fdpi_cli l2tp server stat <IP>
Пример вывода:
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
Описание параметров вывода:
invalid session type — Найденная в PPP DB по l2subs_id сессия не является L2TP-сессиейsession not found — Сессия не найдена в PPP DB по l2subs_idbad L2TP version — Неподдерживаемая версия L2TPmalformed 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 — Превышение ratelimitAS access denied — Запрет создания L2TP-сессий для подсети (=> для AS)MTU exhausted — Превышение MTU (snaplen) при поступлении пакета на обработкуctl retransmit exhausted — Число закрытых сессий из-за исчерпания ретрансмитов ctl-сообщенийFSM violation — Нарушение state machine