|
Ключ
Эта строка удалена.
Это слово было удалено. Это слово было добавлено.
Эта строка добавлена.
|
Изменения (7)
просмотр истории страницы{toc:maxLevel=2} |
h1. Для чего нужен nas_event_daemon |
... |
* При управлении оборудованием по ssh или telnet могут возникать проблемы: ssh может работать недостаточно быстро, telnet часто имеет ограничение на одновременное количество сессий{note} |
h2. Еще немного технических деталей Все службы биллинга (radius, rtsh, и тд) формирующие события на отправку добавляют их сначала в таблицу базы данных EVENTS_STACK_COMPACT, указывая при этом основные данные - что сделать (cmd), с какой учтеной записью (user_id), абонентом (abonent_id), на какой NAS отправить команду (nas_ip), при необходимости по какой услуге (usluga_id) и если это события RADIUS - то ID сессии (acct_session_id). [Ядро биллинга|CarbonBilling:Worker (ядро биллинга)] обрабатывает компактный стек, собирая большой набор переменых для передачи скрипту управления и перемещает их в основной стек (EVENTS_STACK). h3. Конструктор отчетов Используемые таблицы: EVENTS_STACK_COMPACT, EVENTS_STACK. Вряд ли Вам потребуется их использовать в констукрторе отчетов, стеки динамические, но это может быть полезно при отладке из командной строки. h3. API Используемые модели: EventsStackCompact, EventsStack. |
h1.Настройка Переходим на вкладку "ОБОРУДОВАНИЕ", выбираем нужный NAS. Дополнительно > "Количество потоков для отправки команд на оборудование". |
Указываем необходимое количество форков, нажимаем сохранить. (На текущий момент количество форков ограничено, максимум 100.) |
Будут автоматически запускаться новые форки nas_event_daemon. Количество процессов не должно превышать "количество форков" + 1 процесс "родитель". |
При уменьшении количества форков значение не будет изменяться моментально т.к. процессы должны завершить свои задачи. свою работу. |
Контролируем обработку команд с помощью ps aux. Например для микротика: |
... |
h1. Отладка |
h2. Проверьте запущен ли демон Выполните команду "ps aux | grep nas_event_daemon" в терминале, вывод должен быть приблизительно следующим: {code}# ps aux | grep nas_event_daemon root 13560 0.0 0.0 106184 1608 ? Ss 10:40 0:00 /bin/bash /usr/local/sbin/nas_event_daemon root 14291 0.0 0.0 103320 920 pts/0 S+ 10:40 0:00 grep nas_event_daemon {code} Первая строка "*/bin/bash /usr/local/sbin/nas_event_daemon*" говорит о том что демон запущен. h2. Проверьте стек событий на отправку |
Узнать количество команд в стеке с группировкой по типу команды можно выполнив скрипт *event_count.sh*: {code}chroot /app/asr_billing/ event_count.sh{code} |
... |
#* *EVENT_DATE* - дата добавления события в main stack #* *PARAMS* - набор переменных, передаваемый в скрипт событий |
#* *OWNER_SCRIPT* - подсистема [воркера|CarbonBilling:Worker] [воркера|Worker (ядро биллинга)] добавившая событие в стек |
#* *OWNER_FUNCTION* - функция этой под системы в которой вызвано добавление события в стек #* *NAS_ID* - ID NAS/BRAS #* *TRY_COUNT* - количество выполненных попыток отправки команд |
h3. Поиск причины переполнения стека В зависимости от ситуации и схемы интеграции с NAS, нормальным можно считать следующее количество событий: * Штатная работа - до 200 событий суммарно в events_stack и events_stack_compact * Массовая авторизация на NAS (например, после перезагрузки) - до 5 на абонента в суммарно в events_stack и events_stack_compact. Например, на NAS 1000 абонентов. Сразу после перезагрузки NAS может скопиться до 5000 событий из-за большого количества авторизаций в короткий срок. При скоплении событий в стеке, они должны отправляться на оборудование со скоростью около 1000 за 5 минут. Если медленней, то: * Попробуйте увеличить количество форков (описано выше в статье) * Посмотрите лог отправки событий, возможно NAS слишком долго выполняет полученные команды. Отправьте команду вручную и проверьте скорость ответа программой *time*. На примере Mikrotik: {code}# time send_mikrotik_cmd -s 10.90.185.2 admin servicemode /queue simple remove comment=crb_10.88.0.15 ERROR: UnknownParameter message: 'unknown parameter', command: '/queue/simple/remove =comment=crb_10.88.0.15' exit code: 249 real 0m0.096s user 0m0.031s sys 0m0.008s{code} Время +real+ не должно превышать 300 милисекунд. * Возможно БД билинга находится на медленном носителе или прочие аппаратные проблемы мешают работе биллинга. Проведите диагностику по статье "[CarbonBilling:Проблемы с оборудованием]" h2. Проверьте логи h3. Лог демона Он расположен по пути */app/asr_billing/var/log/nas_event_daemon.log* Каждые 60 секунд демон проверяет состояние настройки NAS-серверов в биллинге и синхронизирует их: запускает потоки на новые NAS, актуализирует данные по ранее созданным, останавливает потоки отправки на удаленные NAS. При запуске итерации в лог записывается строка с параметрами каждого NAS-сервера на который будут отправляться команды. Пример записи о NAS-сервере интегрированном по стандартной схеме Mikrotik-Simple: {code}2019-08-27 10:57:41 vm185-120 nas_event_daemon[32736]: Start work with nas nasid=1116 nas_ip=10.90.185.2 oss_pathname=/var/oss/core/Mikrotik-Simple script_name=<null>{code} * *2019-08-27 10:57:41* - дата и время записи * *vm185-120* - hostname опреационной системы * *nas_event_daemon\[32736\]: Start work with nas* - запись о начале работы с NAS, 32736 - PID процесса демона * *nasid=1116* - ID NAS в базе биллинга * *nas_ip=10.90.185.2* - IP-адрес NAS * *oss_pathname=/var/oss/core/Mikrotik-Simple* - путь [директории OSS-схемы|CarbonBilling:Интеграция оборудования интернет] * *script_name=<null>* - путь до скрипта, если [стандартные OSS-схемы не используются|CarbonBilling:Интеграция оборудования интернет] Если в логе нет записи о начале работы с Вашим NAS, возможно: * Выбрана OSS схема, но не [инициализирована|CarbonBilling:Этап 2. Генерация конфигурации и upload на оборудование] * Настройка не была завершена - не выбрана OSS схема или не указан скрипт управления если используется старая схема интеграции * Нет файлов схемы или скрипта управления по указанному пути - такое может произойти при [переносе|CarbonBilling:Перенос на другой сервер или переустановка] на новый сервер h3. Лог NAS Логи по каждому NAS в отдельности сохраняются в папке */app/asr_billing/var/log/nas_event_daemon/*, например: {code}/app/asr_billing/var/log/nas_event_daemon/Test_NAS_10.20.11.15.log{code} Имя файла состоит из [наименования и IP-адреса NAS-сервера|CarbonBilling:Этап 1. Мастер Стандартной схемы NAS] В логе записываются команды вызываемые из скрипта управления. {info}Их можно скопировать прямо из лога и выполнить в командной строке внутри контейнера биллинга, например: {code}chroot /app/asr_billing time send_mikrotik_cmd -s 10.90.185.2 admin servicemode /queue simple remove comment=crb_10.88.0.15{code} Это может сильно помочь в диагностике.{info} Так же в логе отражен ответ NAS-сервера. При возникновении каких-либо ошибок можно попробовать понять по документации NAS в чем именно была проблема. h3. Лог учетной записи Логи учетных записей дублируют данные из лога NAS-сервера, в них пишутся только логи конкретной [учетной записи|CarbonBilling:Учетная запись. Создание и изменение.]. Они располагаются в папке */app/asr_billing/var/log/abonents/*. Рассмотрим на примере: {code}/app/asr_billing/var/log/abonents/1375/event_1424.log{code} * */app/asr_billing/var/log/abonents/* - папка с логами отправленных команд по абонентами и учетным записям * *1375* - ID абонента * event_*1424*.log - название файла, где 1424 - ID учетной записи. По этим логам можно попробовать диагностировать проблему на конкретном абоненте, что может существенно снизить время поиска решения. h2. Как массово отправить команды по абонентам Вам потребуется создать скрипт: * Получите данные абонентов и учетных записей по заданным параметрам [SQL-запросом командой sqlexec|CarbonBilling:Конструктор отчетов] и передайте полученные данные (ID абонентов, учетных записей, IP-адреса и тд) в команду которой управляется оборудование (SSH, RADIUS CoA и тд) * Так же получить данные с sqlexec и передайте их по API создавая объекты в моделе EventsStackCompact, например так: \\ \\ {code}#/bin/bash sqlexec "set list; select id from users u where nas_id=1112" | awk '$2{print $2}' | while read user_id; do curl -XPOST 'http://169.254.80.82:8082/rest_api/v2/EventsStackCompact/' -d 'method1=objects.create&arg1={"user_id": '$user_id',"cmd":"user_redirect_cancel"}' done exit 0{code} |