Способы проверки доступности
Проверка доступности может осуществляться несколькими способами:
-
встроенный режим проверки SIP транка
-
автоматические тестовые звонки
-
Web запросы к API
Встроенный режим проверки доступности SIP транка задается при редактировании SIP провайдера в Режим проверки доступности
. Этот способ определения доступности влияет на выбор правила в настройках маршрутизации звонка. Если SIP транк будет доступен, результирующее действие будет выполнено. Иначе, произойдет переход к другому правилу. В случае когда SIP транк доступен, но при отправке пакета INVITE приходит ответ отличный от поднятия трубки 200 OK - следует использовать дополнительные способы для определения доступности КЦ. Например, заранее производить тестовые звонки, которые будут проверять код SIP ответа. Если коммутация не будет установлена - отключить правило до тех пор, пока повторные тестовые звонки не установят успешную коммутацию.
Для определения состояния через Web запросы на стороне КЦ должна быть возможность обращения к API. Служебный сценарий обращается к методам, которые предоставляют данные о статусе доступности, и исходя из этого происходить маршрутизация звонков.
Исходные данные:
-
Провайдер связи, который предоставляет общий номер телефона для всех контактных центров - ITSP
-
Call-центр 1 - КЦ1
-
Call-центр 2 - КЦ2
Все звонки поступающие на ITSP обрабатываются КЦ1. Если КЦ1 станет недоступным - переключать все поступающие вызовы на обработку на второй резервный КЦ2 до тех пор, пока КЦ1 не станет доступен для звонков.
Встроенный режим проверки доступности
КЦ1 и КЦ2 добавлены в качестве SIP провайдеров с режимом проверки доступности SIP OPTIONS запросов. При данном типе проверки SIP сервер КЦ должен поддерживать OPTIONS пакеты. Возможные и другие способы проверки доступности, такие как SIP REGISTER запрос и STUN взаимодействие.
Настройка SIP транка
КЦ1 и КЦ2 добавлены в качестве SIP провайдеров с режимом проверки доступности SIP OPTIONS запросов. При данном типе проверки SIP сервер КЦ должен поддерживать OPTIONS пакеты. Возможные и другие способы проверки доступности, такие как SIP REGISTER запрос и STUN взаимодействие.
Для изменения настроек на главной странице Bridge открыть приложение администрирования Настройки
. C левой стороны в области Объекты
перейти в раздел SIP транки
- SIP провайдеры
и далее открыть объект для редактирования
Создание вектора
|
На главной странице Bridge открыть приложение администрирования |
|
В качестве направления источника выбраны Внешние линии и в качестве маски кода оператора SIP телефонии указан ITSP. |
Создание правила
Два правила - для КЦ1 c приоритетом 1000 и для КЦ2 - приоритетом с 1001. Таблица маршрутизации первым распределит звонок на SIP транки КЦ1. Если КЦ1 будет недоступен или от КЦ1 не будет получен ответ об успешном приеме звонка, логика распределит звонок по правилу для КЦ2, и так до тех пор, пока КЦ1 будет недоступен. Сразу же как КЦ1 станет доступны, звонки будут распределятся по первому правилу с приоритетом 1000. Таким способом реализуется один из вариантов балансировки распределения звонков.
|
C левой стороны в области |
|
Создать правило для КЦ1, выбрать вектор, приоритет 1000. В качестве результирующего действия выбрать действие Внешняя линия и SIP транк КЦ1. |
|
Создать правило для КЦ2, выбрать вектор, приоритет 1001. В качестве результирующего действия выбрать действие Внешняя линия и SIP транк КЦ2. |
Тестовые звонки проверки доступности
Для мониторинга доступности используется возможность совершения звонков через SIP транки КЦ. Для этого настраивается служебный сценарий, который запускается автоматически с определенной периодичностью. В случае успешного вызова - КЦ готов для обработки вызова, отмечается доступным до следующей проверки. Если звонок не будет принят на стороне КЦ(например, получен SIP ответ 404 Not Found) - происходит переключение звонков на второй резервный КЦ2.
IVR для дозвона
IVR сценарий будет запущен после успешного дозвона. Успешные попытки дозвона фиксируются в лог-журнале.
|
На главной странице Bridge открыть приложение администрирования |
|
Откроется |
|
Откроется редактор сценариев. Разместить Старт и SIP-ответ 200 OK. |
|
Указать достаточное время проверки коммутации - 5 секунд(при необходимости увеличить) |
|
Логировать событие по успешной коммутации в лог-журнале с помощью компонента Уведомление. После всех операций разместить компонент Обрыв связи. Сохранить сценарий - нажать кнопку . |
Запуск дозвона и фиксация статуса звонка
Создание служебного сценария, для автоматизации дозвона на SIP транк КЦ. В сценарии производится тестовый звонок в КЦ1. В случае неуспешного вызова меняется правило маршрутизации, звонки поступают в КЦ2.
|
На главной странице Bridge открыть приложение администрирования |
|
Откроется |
|
Откроется редактор сценариев. Разместить компонент Старт и Операция. Определение текущего приоритета правила в Операция. Для получения указать: тип сущности правила - vectorrule, метод - получить, фильтр - id правила в виде JSON-структуры {"id":"7d02688b-0178-d59e-62e2-005056012e0b"}, поля - |
|
Разместить компонент Парсер, парсинг текущего приоритета правила из переменной полученной в Операция. Документ - переменная |
|
Разместить компонент Исходящий звонок, в свойствах выбрать режим |
|
В качестве номера указать номер 000. Для этого номера будет настроено правило маршрутизации для вектора исходящего звонка. Источник сценария - из списка, сценарий - |
|
Для успешного перехода разместить компонент Сравнение. Для переходов неудача, нет ответа и ошибка - разместить компонент Уведомление |
|
Логировать событие по неуспешной коммутации в лог-журнале с помощью компонента Уведомление |
|
Проверка в Сравнение |
|
Если |
|
Для успешного звонка добавить проверку кода ответа 200 ОК. В компоненте сравнение проверить код ответа, по ветке |
|
Проверка в Сравнение |
|
Изменение приоритета правила с помощью компонента Операция, чтобы поступающие звонки распределялись на правило с КЦ1 после того, как тестовые звонки снова будут успешно проходить. Для обновления указать: тип сущности правила - vectorrule, метод - обновить, данные - в виде JSON-структуры {"id":"7d02688b-0178-d59e-62e2-005056012e0b"+"priority":1001} (id правила и значение приоритета). |
|
Завершить работу сценария компонентом Стоп. Сохранить сценарий - нажать кнопку . |
Создание вектора и правила для набираемого номера 000 из сценария дозвона.
|
C левой стороны в области |
|
Приоритет 1000. В качестве направления источника выбрать Внутренний абонент. |
|
В качестве маски кода назначения указать 000. |
|
C левой стороны в области |
|
Создать правило для номера 000, выбрать вектор созданный ранее |
Создание служебной задачи
Настройка автоматического запуска дозвона. Создание служебной задачи, которая запускает служебный сценарий Запуск дозвона и фиксация статуса звонка с интервалом каждые 10 секунд.
|
C левой стороны в области |
|
Задать название служебной задачи, SVC сценарий для запуска - выбрать ранее созданный сценарий |
|
Кратность запуска - периодический многократный запуск, интервал между запусками - 10 секунд. Нажать . |
Web-запросы к API
Служебная задача запускает служебный сценарий с определенной периодичностью. В служебном сценарии производится выполнение Web-запроса к КЦ. В API КЦ существует метод tst_getintnumberreadyusers, который возвращает количество свободных операторов. Если свободных операторов нет - производится изменение приоритета правила, чтобы звонок распределялся на КЦ2. Если на Web-запрос не будет получен ответ, совершаются еще две попытки отправки Web-запроса, и только после этого производится изменение приоритета правила с переключением по недоступности КЦ.
Создание служебного сценария
|
C левой стороны в области |
|
Откроется |
Создание внешней интеграции
|
В области |
|
Откроется |
|
В блоке |
|
В блоке |
Редактирование служебного сценария
|
Вернутся к ранее созданному сценарию. C левой стороны в области |
|
Откроется редактор сценариев. Разместить компонент Старт и Операция. Определение текущего приоритета правила в Операция. Для получения указать: тип сущности правила - vectorrule, метод - получить, фильтр - id правила в виде JSON-структуры {"id":"7d02688b-0178-d59e-62e2-005056012e0b"}, поля - |
|
Разместить компонент Парсер, парсинг текущего приоритета правила из переменной полученной в Операция. Документ - переменная |
|
Разместить компонент Web-запрос, в свойствах выбрать ранее созданный канал интеграции - |
|
Разместить компонент Парсер, парсинг значения свободных операторов с помощью регулярного выражения. Документ |
|
В компоненте сравнение проверит значение переменное count - количество свободных операторов 0? |
|
Если операторов 0 и для Web-запроса по таймауту и ошибке - перевести на цикл дополнительной проверки. Для цикла создать переменную |
|
Уменьшит значение cycle на единицу. |
|
Проверить значение cycle = 0 ? Если да - то переключить на КЦ2, если нет - повторно отправить Web-запрос. |
|
Перед переключением на КЦ2 проверка в Сравнение |
|
Если |
|
Если свободных операторов больше 0, проверить значение текущего приоритета, если если 1000 - Стоп. |
|
Изменение приоритета правила с помощью компонента Операция, чтобы поступающие звонки распределялись на правило с КЦ1 после того, как Web-запрос вернет нужное значение свободных операторов. Для обновления указать: тип сущности правила - vectorrule, метод - обновить, данные - в виде JSON-структуры {"id":"7d02688b-0178-d59e-62e2-005056012e0b"+"priority":1001} (id правила и значение приоритета). Сохранить сценарий - нажать кнопку . |
Создание служебной задачи
Настройка автоматического запуска сценария, выполняющего Web-запросы к API КЦ. Сценарий будет запускаться каждые 10 секунд.
|
C левой стороны в области |
|
Задать название служебной задачи, SVC сценарий для запуска - выбрать ранее созданный сценарий |
|
Кратность запуска - периодический многократный запуск, интервал между запусками - 10 секунд. Нажать . |
Балансировка и дополнительные параметры
Различные варианты настройки векторов и правил позволяют реализовать любые варианты балансировки. Можно использовать встроенные способы и получение данных о состоянии во внешних источниках. В случае, если указать одинаковые приоритеты для правил при Создание правила в Встроенный режим проверки доступности - звонки будут распределяться в случайном порядке на КЦ1 и КЦ2. Если требуется реализация более сложных алгоритмов, или получение приоритетов из внешних источников - через Web-запросы API, CLI, баз данных - присутствует возможность реализации с помощью служебных сценариев, по аналогии с Создание служебного сценария в Web-запросы к API. Все эти способы можно комбинировать и с одновременным мониторингом через Тестовые звонки проверки доступности.