Для відображення статистики використання каналів в Asterisk можна використовувати Nagios або MRTG.
Пораду знайшов у
http://karlsbakk.net/asterisk/
http://rad.kiev.ua/asterisk_manager_interface
http://the-asterisk-book.com/1.6/asterisk-manager-api.html
Оскільки MRTG вже використовується вирішив і для цього випадку використати MRTG.
Скрипт збирання результатів asterisk-mrtg взяв у
http://karlsbakk.net/asterisk/scripts/asterisk-mrtg
У файлі /etc/mrtg/mrtg.cfg прописав запуск скрипта
Title[servername]: Server title
PageTop[servername]: <h1>servername.domain.com</h1>
Target[servername]: `/usr/local/bin/asterisk-mrtg -h servername.domain.com -u someuser -p Password -1 SIP -2 IAX2`
Options[servername]: gauge,integer
MaxBytes[servername]: 90
YLegend[servername]: Active channels
ShortLegend[servername]: chn
Повний синтаксис командного рядка asterisk-mrtg вказаний прямо в тілі скрипта.
Для доступу скрипта до результатів Asterisk необхідно ввімкнути та налаштувати AMI (Asterisk Manager API). Для цього потрібно змінити або створити файл /etc/asterisk/manager.conf
[general]
enabled = yes
port = 5038
bindaddr = 10.0.0.1
[someuser]
secret=Password
deny=0.0.0.0/0.0.0.0
permit=10.0.0.0/255.255.255.0
read = system,call,log,verbose,command,agent,user,config
write = system,call,log,verbose,command,agent,user,config
Хоча будемо тільки читати результати, все одно потрібно вказати опцію write, вказати write=none або не вказати опцію write не можна, без такої опції доступ до результатів заборонений.
Цю пораду знайшов у
http://lists.digium.com/pipermail/asterisk-users/2008-February/205478.html
Після перезапуску Asterisk або перезавантаження модуля за допомогою
asterisk -rx "module reload manager"
можна перевірити функціонування AMI, наприклад за допомогою
telnet 10.0.0.1 5038
або запустити скрипт
/usr/local/bin/asterisk-mrtg -h servername.domain.com -u someuser -p Password -1 SIP -2 IAX2
Результат повинен бути у вигляді
10
Пораду знайшов у
http://karlsbakk.net/asterisk/
http://rad.kiev.ua/asterisk_manager_interface
http://the-asterisk-book.com/1.6/asterisk-manager-api.html
Оскільки MRTG вже використовується вирішив і для цього випадку використати MRTG.
Скрипт збирання результатів asterisk-mrtg взяв у
http://karlsbakk.net/asterisk/scripts/asterisk-mrtg
У файлі /etc/mrtg/mrtg.cfg прописав запуск скрипта
Title[servername]: Server title
PageTop[servername]: <h1>servername.domain.com</h1>
Target[servername]: `/usr/local/bin/asterisk-mrtg -h servername.domain.com -u someuser -p Password -1 SIP -2 IAX2`
Options[servername]: gauge,integer
MaxBytes[servername]: 90
YLegend[servername]: Active channels
ShortLegend[servername]: chn
Legend1[servername]: Channels
Legend2[servername]: Channels
LegendI[servername]: SIP:
LegendO[servername]: IAX:
Повний синтаксис командного рядка asterisk-mrtg вказаний прямо в тілі скрипта.
Для доступу скрипта до результатів Asterisk необхідно ввімкнути та налаштувати AMI (Asterisk Manager API). Для цього потрібно змінити або створити файл /etc/asterisk/manager.conf
[general]
enabled = yes
port = 5038
bindaddr = 10.0.0.1
[someuser]
secret=Password
deny=0.0.0.0/0.0.0.0
permit=10.0.0.0/255.255.255.0
read = system,call,log,verbose,command,agent,user,config
write = system,call,log,verbose,command,agent,user,config
Хоча будемо тільки читати результати, все одно потрібно вказати опцію write, вказати write=none або не вказати опцію write не можна, без такої опції доступ до результатів заборонений.
Цю пораду знайшов у
http://lists.digium.com/pipermail/asterisk-users/2008-February/205478.html
Після перезапуску Asterisk або перезавантаження модуля за допомогою
asterisk -rx "module reload manager"
можна перевірити функціонування AMI, наприклад за допомогою
telnet 10.0.0.1 5038
або запустити скрипт
/usr/local/bin/asterisk-mrtg -h servername.domain.com -u someuser -p Password -1 SIP -2 IAX2
Результат повинен бути у вигляді
10
0
0
10
Якщо збирання результатів працює нормально, то необхідно запустити indexmaker для генерації /mrtg/index.html.
Можна спробувати замість скрипта використати команди, як вказано у
http://www.commandlinefu.com/commands/view/5179/watch-active-calls-on-an-asterisk-pbx
Після оновлення Asterisk до версії 13.3, на графіку MRTG перестав показувати результати.
Виявляється змінився формат звіту AMI, у результат після команди
Action: Status
додався ще рядок
EventList: start
Тому треба в asterisk-mrtg додати строки, які виявляють додаткові результати
Скрипт з строки 121 повинен виглядати
$response = <$sock>;
$eventl = <$sock>;
$message = <$sock>;
print $response.$eventl.$message if ($verbose);
&unknown("Unknown answer $response (wanted Response: something)") unless ($response =~ m/^Response:\s+(.*)$/i);
&unknown("$response didn't say Success") unless ($1 =~ m/Success/i);
&unknown("Unknown answer $eventl (wanted EventList: start)") unless ($eventl =~ m/^EventList:\s+(.*)$/i);
&unknown("$eventl didn't say start") unless ($1 =~ m/start/i);
&unknown("Unknown answer $response (wanted Message: something)") unless ($message =~ m/^Message:\s+(.*)$/i);
&unknown("didn't understand message $message") unless ($1 =~ m/Channel status will follow/i);
І в самому початку треба задати визначення нової змінної $eventl.
У вигляді
my (
$version, $response, $eventl, $message, $line, $chan1, $chan2,
Якщо збирання результатів працює нормально, то необхідно запустити indexmaker для генерації /mrtg/index.html.
Можна спробувати замість скрипта використати команди, як вказано у
http://www.commandlinefu.com/commands/view/5179/watch-active-calls-on-an-asterisk-pbx
Після оновлення Asterisk до версії 13.3, на графіку MRTG перестав показувати результати.
Виявляється змінився формат звіту AMI, у результат після команди
Action: Status
додався ще рядок
EventList: start
Тому треба в asterisk-mrtg додати строки, які виявляють додаткові результати
Скрипт з строки 121 повинен виглядати
$response = <$sock>;
$eventl = <$sock>;
$message = <$sock>;
print $response.$eventl.$message if ($verbose);
&unknown("Unknown answer $response (wanted Response: something)") unless ($response =~ m/^Response:\s+(.*)$/i);
&unknown("$response didn't say Success") unless ($1 =~ m/Success/i);
&unknown("Unknown answer $eventl (wanted EventList: start)") unless ($eventl =~ m/^EventList:\s+(.*)$/i);
&unknown("$eventl didn't say start") unless ($1 =~ m/start/i);
&unknown("Unknown answer $response (wanted Message: something)") unless ($message =~ m/^Message:\s+(.*)$/i);
&unknown("didn't understand message $message") unless ($1 =~ m/Channel status will follow/i);
І в самому початку треба задати визначення нової змінної $eventl.
У вигляді
my (
$version, $response, $eventl, $message, $line, $chan1, $chan2,
Також можна спростити файл налаштувань AMI.
Для отримання результату достатньо у manager.conf вказати
read = reporting
write = reporting
write = reporting
Коментарі
Дописати коментар