Nginx-ru mailing list archive (nginx-ru@sysoev.ru)
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: Мониторинг скорости ответа бэкенда
On Wednesday 13 June 2007, Монашёв Михаил wrote:
> Здравствуйте.
>
> Если в логи писать $upstream_response_time, то можно с его помощью
> мониторить скорость работы бэкенда. Но при большом количестве запросов
> агрегировать логи за последние 5 минут, чтобы вытянуть из них одну
> циферку - среднее значение $upstream_response_time, дороговато.
>
> Есть идеи как делать это быстро?
>
> > Попробуйте включить в лог $upstream_response_time, или $request_time,
> > обновив nginx
Уже год использую мониторинг через tail -F в перл скрипте, дамп статистики в
файл, импорт этого файла в snmpd и показ графиков в zabbix.
В аттаче перл скрипт.
/etc/snmp/snmpd.conf :
exec .1.3.6.1.4.1.2021.80 nginx_extra /bin/cat /tmp/nginx2snmpd.txt
Формат лога
log_format ultimate '[$time_local] "$country" $remote_addr
$request_length $bytes_sent $status $site_name
$host "$request" "$sent_http_content_type"
"$sent_http_location" "$http_user_agent" "$http_referer" "$request_time
$upstream_response_time" "$upstream_addr" "$http_x_forwarded_for"';
Т.к. недавно появилась переменная $upstream_addr, то стало интересно
мониторить время ответов конкретных апстримов. Но пока не дошли до этого
руки.
Attachment:
nginx2snmpd.pl
Description: Perl program
|