[#] Asterisk: Приоритезация VoIP трафика и резервирование доступа в Интернет двух провайдеров на MikroTik
habrabot(difrex,1) — All
2015-11-27 13:30:02


Казалось бы вещи, вынесенные в заголовок, достаточно тривиальны и описаны во множестве мест глобальной сети, но это только на первый взгляд. Опробовав наиболее часто встречающиеся советы я обнаружил несколько «подводных камней», глыб и даже скальных образований. Но это все слова, ближе к делу. Достаточно распространенная ситуация — Asterisk внутри ЛКС, за маршрутизатором MikroTik. Дабы выделить трафик сервера, где установлена PBX, администратор отрезает часть канала провайдера выделяя его исключительно для конкретного IP. Или другая реализация, когда нужный трафик определяется не только по IP-адресу PBX, но и по размеру пакетов и протоколу. Попробовали — работает. Можно забыть? А вот и нет. Что если администратору захочется слить что-то из Интернет находясь в консольке сервера, или наоборот отправить куда-либо в Интернет большое количество траффика? Правильно — он приоритезируется на MikroTik так же как и полезный трафик от PBX, что в итоге приведет к проблемам с IP-телефонией. Решение здесь старо как сам IPv4 — метить трафик на сервере с Asterisk генерируемый только ею, и так, чтобы MikroTik это мог «увидеть», отматчить(простите за столь грубый англицизм) и приоритезировать только его. Следующим пунктом у нас идет резервирование каналов от двух интернет-провайдеров. Думаю что каждому системному администратору, использующему в своем хозяйстве маршрутизаторы MikroTik, знаком скрипт из wiki — [wiki.mikrotik.com/wiki/Failover\_Scripting][1] Он всем хорош, но как и в предыдущей ситуации есть ряд «но». Наиболее весомому из них имя «Connection tracking» и заключается оно вот в чем: когда наш основной ISP изволит отдохнуть от трудов праведных, траффик переключается на резервного. Все вроде бы довольны, ютуб работает, яп тоже, но сколько бы мы не кричали



и в отчаянии не пытались применить магию высших порядков



SIP-регистрации не поднимаются. А дело в том, что в механизме «Connection tracking» остались висеть записи от «старого»(основного) интернет-канала и их нужно удалить, после чего регистрации успешно поднимутся и звонки начнут проходить. Если вам интересно как доказать MikroTik'у кто все-таки верблюд, а так же как автоматизировать в скрипте сброс «старых» соединений, то вам прямо под кат. [Читать дальше →][2]

[1]: http://wiki.mikrotik.com/wiki/Failover_Scripting
[2]: http://habrahabr.ru/post/271747/#habracut