Обновление моей старой и популярной статьи на тему мониторинга. В этой заметке мы займемся настройкой мониторинга web сервера nginx, apache и php-fpm в zabbix сервере с помощью готовых шаблонов. Полученная информация может пригодиться при анализе нагрузки на сайт, его скорости, при оценке качества хостинга, для прогнозирования максимально возможной посещаемости.
Научиться настраивать MikroTik с нуля или систематизировать уже имеющиеся знания можно на углубленном онлайн-курcе по администрированию MikroTik. Автор курcа – сертифицированный тренер MikroTik Дмитрий Скоромнов. Более 40 лабораторных работ по которым дается обратная связь. В три раза больше информации, чем в MTCNA.
Реклама ИП Скоромнов Д.А. ИНН 331403723315
Содержание:
Цели статьи
- Подобрать набор критичных метрик web сервера для мониторинга.
- Разработать инструменты для подготовки данных и передачи в zabbix, с учетом современных нововведений последних версий.
- Подготовить шаблоны для мониторинга nginx, apache, php-fpm.
- Показать пример готового дашборда, который использую я для мониторинга за веб сервером.
Введение
Если у вас еще нет своего сервера для мониторинга, то рекомендую материалы на эту тему. Для тех, кто предпочитает систему CentOS:
То же самое на Debian 10, если предпочитаете его:
Я буду в своем примере настраивать все на CentOS 7, но в данном случае дистрибутив не имеет принципиального значения, все так же настраивается и на других linux системах с учетом их особенностей в установке пакетов и путей для конфигов и программ.
Мы будем использовать в качестве источника информации штатные возможности nginx, apache и php-fpm, затем передавать данные в zabbix сервер и там анализировать. Я подразумеваю, что nginx или apache вы уже настроили и имеете некое представление о работе его компонентов, поэтому некоторые вещи я не разжевываю, а просто говорю, что делать.
Подготовка nginx к мониторингу
Я планирую мониторить следующие параметры nginx:
accepts per second | Число принятых соединений в секунду |
active connections | Текущие активные соединения |
handled per second | Число обработанных соединений в секунду |
latency | Время ответа сервера в миллисекундах |
memory allocated | Занимаемая память |
process count | Число запущенных процессов |
reading state connection count | Текущее число соединений, в которых nginx в настоящий момент читает заголовок запроса |
requests per second | Число запросов в секунду |
waiting state connection count | Текущее число бездействующих соединений в ожидании запроса |
writing state connection count | Текущее число соединений, в которых nginx в настоящий момент отвечает |
memory allocated | Сколько памяти занимают все worker process |
Сервер nginx умеет отдавать часть необходимой нам информации о своем состоянии. Для этого его надо соответствующим образом подготовить. Открываем конфиг сервера и добавляем туда следующую конструкцию:
server { listen localhost; server_name localhost; keepalive_timeout 0; allow 127.0.0.1; allow ::1; deny all; access_log off; location /nginx-status { stub_status on; }
Я обычно добавляю в самый конец основного конфига nginx.conf. Сохраняем и перечитываем конфигурацию, перед этим проверив его конфиг на ошибки:
# nginx -t # nginx -s reload
Проверяем, можем ли мы получить необходимую информацию для настройки мониторинга:
# curl http://localhost/nginx-status Active connections: 89 server accepts handled requests 1374661 1374661 9511381 Reading: 0 Writing: 1 Waiting: 87
Теперь проверим, сможет ли zabbix получать эту страницу.
# zabbix_agentd -t web.page.get[localhost,nginx-status,80]
Если у вас так же, то все в порядке, можно двигаться дальше. Если что-то не получается, то проверяйте конфиги, смотрите логи. Это штатный функционал, он должен без проблем настраиваться и работать.
Сразу обращаю внимание на один важный момент, на котором я застрял на приличное время. Через curl я без проблем забирал страничку со статусом nginx, а вот через zabbix никак не получалось. Была ошибка:
[m|ZBX_NOTSUPPORTED] [HTTP get error: cannot connect to [[localhost]:80]: [111] Connection refused]
Я всю голову сломал, 10 раз перепроверил конфиги, никак не мог понять, почему не работает. Оказалось, дело было вот в чем. Zabbix-agent обращался к серверу Nginx по протоколу ipv6. Это при том, что как агент, так и nginx работали по ipv4. Я принудительно отключаю у служб ipv6, если он не используется.
Обнаружил это случайно, когда от безысходности запустил Nginx на всех интерфейсах и снял ограничения allow/deny в конфиге. Тогда запрос прошел нормально. Я посмотрел access лог и увидел, что zabbix-agent обращается с адреса ::1. И все стало ясно. Я так и не понял, как заставить агента ходить по ipv4. В итоге запустил nginx на обоих протоколах и разрешил забирать страницу статуса с адреса ::1. После этого заработало.
Самое неприятное в этой ситуации было то, что в логах нигде не было никаких ошибок, отклоненных запросов или чего-то еще, что могло бы дать зацепку. Zabbix agent просто писал, что подключение отклонено и все. О том, что он обращается по ipv6, не было никакого намека.
Настройка в zabbix мониторинга nginx
В прошлой редакции этой статьи дальше шло описание скрипта, который будет парсить вывод nginx-status и передавать данные в zabbix. Сейчас все можно сделать гораздо проще и удобнее. На агенте не надо ничего настраивать. Все выполняется исключительно в шаблоне. То есть вам достаточно загрузить готовый шаблон для мониторинга nginx на zabbix сервер, прикрепить его к хосту и все будет работать.
Это удобный подход, который избавляет от необходимости настраивать агентов. Теперь все выполняется с сервера. Минус этого подхода только в том, что возрастает нагрузка на сервер мониторинга. Это плата за удобство и централизацию. Имейте это ввиду. Если у вас большая инсталляция мониторинга и есть средства автоматизации типа ansible, возможно вам имеет смысл по старинке парсить данные скриптом. Но в общем случае я рекомендую делать так, как я расскажу далее.
Суть мониторинга Nginx будет сводиться к тому, что мы через агента станем забирать страницу http://localhost/nginx-status на сервер. Там с помощью регулярных выражений и зависимых элементов данных будем формировать нужные метрики.
Представляю вам готовый шаблон для мониторинга nginx. Скачиваем его zabbix-nginx-template.xml и открываем web интерфейс zabbix сервера. Идем в раздел Configuration -> Templates и жмем Import:
Выбираем файл и снова нажимаем Import:
Шаблон я подготовил сам на основе своих представлений о том, что нужно мониторить. Проверил и экспортировал его с версии 4.2 Регулярные выражения для парсинга html страницы статуса подсмотрел тут - https://github.com/AlexGluck/ZBX_NGINX. К представленному шаблону я добавил некоторые итемы и переделал все триггеры. Плюс убрал макросы. Не вижу в них в данном случае смысла.
В шаблоне 11 итемов, описание которых я привел ранее.
Подробнее остановимся на триггерах. Их 5 штук.
- Many active connections - срабатывает если среднее количество соединений за последние 10 минут больше в 3 раза, чем среднее количество за интервал на 10 минут ранее.
- many requests и too many requests - срабатывают, когда среднее количество запросов за последние 10 минут больше в 3 и 6 раз соответственно, чем на 10 минут ранее.
- nginx is not running - тут все просто. Если не запущен ни один процесс nginx, шлем уведомление.
- nginx is slow to respond - срабатывает если время выполнения запроса на получение страницы со статусом за последние 10 минут больше предыдущих 10 минут в 2 раза.
С триггерами больше всего вопросов. Предложенная мной схема может работать независимо от проекта, не требует начальной калибровки, но могут быть ложные срабатывания из-за разовых очень сильных всплесков, которые быстро проходят, но сильно меняют средние параметры на интервале.
Более надежно могут сработать триггеры, где явно указаны лимиты в конкретных значениях. Но такой подход требует ручной калибровки на каждом проекте в отдельности. Надо смотреть средние значения метрик и выставлять лимиты в зависимости от них. Если проект будет расти, то лимиты постоянно придется менять. Это тоже не очень удобно и не универсально.
Я в итоге остановился на анализе средних значений, не используя конкретных лимитов. Как поступать вам, решайте отдельно, в зависимости от ситуации. Если у вас один проект, которому вы уделяете много внимания, то ставьте лимиты руками на основе анализа средних параметров. Если работаете на потоке с множеством проектов, то можно использовать мой вариант, он более универсален и не требует ручной правки.
Единственное, коэффициенты можно поправить, если будут ложные срабатывания. Но я обычно этот момент решаю через отложенные уведомления. Если чувствительность триггера очень высокая и есть кратковременные ложные срабатывания, меня они не беспокоят из-за 5-ти минутной задержки уведомлений. Зато при разборе инцидентов, эти кратковременные срабатывания помогают оценить ситуацию в целом.
С мониторингом nginx почти все готово. Теперь нам нужно прицепить добавленный шаблон к web серверу, который мы мониторим и дождаться поступления данных. Проверить их можно в Monitoring -> Latest Data:
В шаблоне есть несколько графиков. Не буду о них рассказывать, так как последнее время практически не пользуюсь графиками. Вместо этого собираю дашборды. Это более удобно и информативно. Жаль, что дашборды нельзя к шаблонам прикреплять. Очень хлопотно каждый раз вручную их составлять и тратить время. В конце покажу пример дашборда, который я использую для мониторинга web сервера.
На этом настройка мониторинга nginx закончена, можно пользоваться.
Подготовка php-fpm к мониторингу
Переходим к мониторингу php-fpm. Он отдает побольше метрик, не буду описывать их все. Рассмотрю только самые основные. Мы будем наблюдать следующие параметры php-fpm:
active processes count | Число активных процессов |
connections per sec | Количество соединений в секунду |
idle processes count | Количество idle процессов |
slow requests | Количество медленных запросов |
length of listen queue | Размер очереди ожидающих подключений |
max children reached | Сколько раз был достигнут лимит по процессам |
max length of listen queue | Максимальный размер очереди подключений |
Пару слов о том, зачем это нужно и как пользоваться полученными данными. Этот мониторинг актуален, если у вас динамическое создание процессов в php-fpm. К примеру, если у вас значение max children reached регулярно больше единицы, то вам рекомендуется увеличить лимит на максимальное количество процессов, если позволяют ресурсы сервера. То же самое относится и к параметру length of listen queue. Если он больше нуля, то создается очередь из запросов, которые не успевают обработать сервер. Необходимо увеличить количество процессов, которые смогут обработать ожидающие подключения.
Приступаем к настройке мониторинга php-fpm на web сервере. Установим fcgi:
# yum install fcgi
Теперь подготовим pfp-fpm для сбора статистики. Для этого мы снова воспользуемся nginx. Редактируем его конфиг, добавляя в ту же секцию server, что и на прошлом этапе, следующую конструкцию:
location /phpfpm-status { include fastcgi_params; fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; }
Перезапускаем nginx:
# systemctl restart nginx
Внесем необходимые изменения в конфиг php-fpm - добавим одну строку:
# mcedit /etc/php-fpm.d/www.conf pm.status_path = /phpfpm-status
Перезапускаем php-fpm:
# systemctl restart php-fpm
Проверяем, что по указанному адресу мы получаем статистику php-fpm:
# curl http://localhost/phpfpm-status
И ее же в формате json.
# curl -s 'http://localhost/phpfpm-status?json' {"pool":"www","process manager":"dynamic","start time":1566494413,"start since":2049,"accepted conn":3236,"listen queue":0,"max listen queue":0,"listen queue len":0,"idle processes":5,"active processes":1,"total processes":6,"max active processes":6,"max children reached":0,"slow requests":0}
Если у вас примерно то же самое, то все в порядке, php-fpm отдает информацию о своем состоянии.
Мониторинг php-fpm в zabbix
Теперь настраиваем мониторинг php-fpm на сервере zabbix. Действуем по аналогии с мониторингом nginx. Забираем страницу состояния php-fpm на сервер мониторинга и там его парсим в зависимых элементах данных.
С php-fpm будет один нюанс. Нам все-таки придется менять параметры zabbix agent. Настраивать мониторинг php-fpm очень легко, потому что он из коробки умеет отдавать все свои метрики в формате json. Это очень удобно, так как его не надо парсить регулярками. Достаточно только указать JSONpath для получения необходимой метрики.
Нам нужно добавить один UserParameter следующего содержания.
UserParameter=phpfpm.json[*],curl -s 'http://localhost/phpfpm-status?json' | tr ' ' _
Перезапускаем zabbix-agent и проверяем, что он корректно возвращает необходимые данные.
# systemctl restart zabbix-agent # zabbix_agentd -t phpfpm.json phpfpm.json [t|{"pool":"www","process_manager":"dynamic","start_time":1566494413,"start_since":3525,"accepted_conn":5820,"listen_queue":0,"max_listen_queue":0,"listen_queue_len":0,"idle_processes":6,"active_processes":1,"total_processes":7,"max_active_processes":7,"max_children_reached":0,"slow_requests":0}]
Дальше как и в случае с nginx, идем в веб интерфейс и импортируем шаблон zabbix-phpfpm-template.xml. Добавляем этот шаблон к серверу и ждем обновления данных. Проверяем их поступление, как обычно, в Monitoring -> Latest Data:
Если все в порядке, то проверяйте графики, создавайте необходимые дашборды. Я свой покажу в самом конце.
В шаблоне php-fpm настроен только один триггер, который следит за тем, чтобы хотя бы один процесс php-fpm был запущен. Раньше я использовал больше триггеров, но потом решил, что они не очень нужны. Состояние работы сайта лучше оценивать по финальным метрикам, таким как скорость загрузки страниц, доступность сайта и коды ответов. Об этом я подобно написал в статье про мониторинг сайта в zabbix. Если с этими метриками проблемы, нужно идти в мониторинг, смотреть графики и решать, что нужно изменить в конфигурации. Это мое личное мнение, с ним можно поспорить. Для этого есть комментарии, буду рад замечаниям и обсуждениям по существу.
Подготовка apache к мониторингу
Приступим к настройке мониторинга web сервера apache. В данном примере я буду использовать web сервер для сайта на bitrix, работающего в окружении bitrixenv. В целом, тут никаких принципиальных отличий нет от обычного apache, просто представлена готовая конфигурация с обширными настройками.
С веб сервером apache мне давно не приходилось связываться в отрыве от bitrix сайтов, поэтому решил показать его мониторинг на его примере. Здесь принцип будет такой же, как и раньше - забираем страницу с информацией о веб сервере, который apache нам предоставляет через свой модуль mod_status.
Дальше мы передаем страницу в zabbix server и там парсим регулярками по зависимым элементам данных. Первым делом вам надо настроить указанный выше модуль. Подробности на официальном сайта - https://httpd.apache.org/docs/current/mod/mod_status.html. Если кратко, то просто добавьте в конфиг apache примерно следующие настройки.
<Location "/server-status"> SetHandler server-status Require host localhost </Location>
Bitrixenv автоматически все настроит, если вы через консольное меню включите Monitoring in pool. Запустится роль ansible, которая настроит в том числе apache, установит и запустит nagios и munin. Если они вам не нужны, то просто добавьте приведенный выше кусок конфига в /etc/httpd/bx/custom/z_bx_custom.conf.
Listen localhost:8886 <IfModule mod_status.c> ExtendedStatus On </IfModule> <VirtualHost localhost:8886> <Location /server-status> SetHandler server-status Require ip 127.0.0.1 require ip ::1 </Location> </VirtualHost>
После этого проверьте настройки apache и перезапустите его.
# apachectl -t # apachectl restart
Если все настроили правильно, то состояние apache можно посмотреть в консоли.
# curl http://localhost:8886/server-status?auto Total Accesses: 1051 Total kBytes: 104324 CPULoad: 4.7515 Uptime: 1835 ReqPerSec: .572752 BytesPerSec: 58216.8 BytesPerReq: 101644 BusyWorkers: 1 IdleWorkers: 29 Scoreboard: _______________________W______
И на всякий случай проверьте, что zabbix-agent может получать эту же информацию.
# zabbix_agentd -t web.page.get[localhost,server-status?auto,8886]
Должны увидеть то же самое, только со служебными заголовками в начале. Если у вас все в порядке, то можно двигаться дальше.
Настройка мониторинга apache
Теперь настроим мониторинг apache в zabbix server. Как обычно, я подготовил шаблон с итемами и триггерами, которые посчитал полезными. Скачиваем его - zabbix-apache-template.xml.
Обратите внимание на элемент, который забирает страницу со статусом. Его url я реализовал через макросы:
- {$S_HOST} - название виртуального хоста
- {$S_PATH} - путь к странице со статистикой
- {$S_PORT} - порт сервера apache, на котором работает статистика
Вот как выглядят настройки макроса на типичном сайте с bitrixenv.
Так же обращаю внимание на итемы проверки количества рабочих процессов и занимаемой виртуальной памяти. Для проверки процессов указан пользователь bitrix, от которого работают все воркеры. В случае проверки памяти указан пользователь root, так как основной процесс запущен от него. А все воркеры используют разделяемую память. Ее суммарный объем, особенно когда воркеров много, огромен и представляет из себя нереальную цифру. Отслеживать ее нет никакого смысла.
Так как apache обычно работает в роле бэкенда, у него минимум триггеров, как и у php-fpm. Я сделал 2:
- Apache service not work - предупреждение о том, что системный процесс web сервера apache не запущен.
- Failed to fetch apache server status page - триггер срабатывает, если не получается загрузить страницу со статистикой.
Добавил еще пару графиков. Сами на них посмотрите. Вот в общем-то и все. После настройки шаблона для мониторинга apache, прикрепите его к хосту, не забудьте указать макросы и ждите поступления данных.
На это про мониторинг apache в zabbix все. Дальше идет пример готового Dashboard.
Дашборд Zabbix для Web сервера
Как и обещал, в завершении статьи по настройке мониторинга web сервера, показываю пример своего дашборда в zabbix для мониторинга bitrix сайта. Картинка очень большая, по клику открывается полная версия, если открыть в новой вкладке.
В самом верху список текущих проблем. В настоящий момент висит активный триггер о ssh подключению к серверу. Описание его настройки - мониторинг ssh подключений. Справа от списка проблем - мониторинг бэкапов в zabbix.
Рекомендую сделать обе настройки. Первая очень помогает понимать, что происходит с сайтом и сервером, если с ним работают несколько человек. Если разработчик залез на сервер по ssh - жди беды. С бэкапами и так все понятно - без них никуда. Возможно как-нибудь отдельно напишу, как я бэкаплю сайты, чтобы защищаться от различного рода угроз и быстро восстанавливать функционирование сайта после сбоев. Просто скопировать весь сайт в другое место недостаточно, особенно если он очень большой. Нужен отдельный продуманный подход к этому вопросу. Напишите в комментариях, если вам интересно получить эту информацию.
Ниже идут метрики с мониторинга web сайта. Выбирается контрольный набор из нескольких страниц (обычно 3-5) и настраивается мониторинг времени ответа и скорости загрузки этих страниц. Для этих параметров настроены триггеры, так как они очень важны. По сути, это ключевые метрики. Если с ними проблемы, надо внимательно смотреть web сервер и разбираться, в чем проблема. Мониторинг web сайта нужно настраивать минимум с двух независимых серверов zabbix, иначе вы не сможете отличить проблемы доступа с сервера мониторинга к сайту от реальных проблем сайта. Только если оба сервера мониторинга сигнализируют о проблемах, можно сделать однозначный вывод о том, что с сайтом и web сервером что-то не так.
Дальше идут метрики из шаблонов, которые я рассмотрел в этой статье. Если у вас вместо apache используется php-fpm, то все примерно то же самое, только в самом низу метрики от php-fpm. Не буду приводить пример с ним, чтобы не загромождать статью. Думаю, приведенного дашборда и так достаточно.
В принципе, сюда можно было бы добавить информацию по I/O дисков, инфу с сетевого стека, данные Mysql. Не стал этого делать, так как это обзорный dashboard, который беглым просмотром позволяет оценить состояние сервера. Так же этот дашборд можно показать заказчику. Для более глубокого анализа проблем, нужно собирать отдельную панель.
Заключение
Подведем итог того, что мы сделали:
- Настроили сервисы nginx, apache, php-fpm таким образом, чтобы они отдавали информацию о своем состоянии.
- С помощью zabbix агентов передали эту информацию на сервер.
- Используя зависимые элементы (dependent items) настроили парсинг метрик.
- Настроили на сервере мониторинга необходимые шаблоны и прикрепили их к наблюдаемым серверам.
- Собрали dashboard для мониторинга за веб сервером.
То есть выполнили весь комплекс действий для организации полноценного мониторинга web сервера в zabbix.
Одно из применений подобного мониторинга - выбор более быстрого хостинга для сайта. К примеру, мне некоторое время назад понадобилось сменить хостинг. Но как узнать, будет ли он быстрее текущего или нет. Характеристики примерно у всех одинаковые. Я просто взял тестовый период, настроил на сервере все, что мне нужно, в том числе мониторинг веб сервера, перенес туда сайт и понаблюдал сутки. Уже по времени отклика nginx и php-fpm мне стало понятно, что новый хостинг быстрее:
Время отклика страниц сайта и скорость их загрузки в целом тоже улучшились. Я однозначно понял, что надо переезжать и не ошибся.
Это пример из старой версии статьи, где показаны старые метрики и графики. Оставил его, так как он в целом информативен. Текущий мониторинг web сайта так же можно использовать для анализа производительности хостинга.
Научиться настраивать MikroTik с нуля или систематизировать уже имеющиеся знания можно на углубленном онлайн-курcе по администрированию MikroTik. Автор курcа – сертифицированный тренер MikroTik Дмитрий Скоромнов. Более 40 лабораторных работ по которым дается обратная связь. В три раза больше информации, чем в MTCNA.
Реклама ИП Скоромнов Д.А. ИНН 331403723315
Здравствуйте!
Я только начал изучать Zabbix. Установил версию 6.4.
Но почему-то в родных в шаблонах очень мало триггеров. попробовал удалить шаблон и загрузить его снова из репозитория, но это ничего не меняет. Например в вашем шаблоне nginx пять триггеров, а в родном от zabbix один. Объясните почему так?
Шаблоны в этой статье самодельные, а не родные. Да и писалась статья давно. В ней многое уже неактуально.
а как маниторить nginx HTTPS?
Приветствую.
При импорте шаблона nginx а 5.0 ошибка
Не удалось прочитать XML: (68) StartTag: invalid element name [Строка: 842 | Колонка: 73].
Вот строка 842
{Template App Nginx:nginx.active.connect.avg(#10)}<{Template App Nginx:nginx.active.connect.avg(#10,600)}*1.2
http://prntscr.com/1xamh9q
Я всю голову сломал, 10 раз перепроверил конфиги, никак не мог понять, почему не работает. Оказалось, дело было вот в чем. Zabbix-agent обращался к серверу Nginx по протоколу ipv6. Это при том, что как агент, так и nginx работали по ipv4. Я принудительно отключаю у служб ipv6, если он не используется.
лечится редактированием файла host на zabbix.
комментируем строку ::1
Да, я тоже очень долго с этим ковырялся. Неужели в статье об этом нет? Давно писал, уже не помню. Но на грабли с ipv6 точно наступал.
Приветствую настраиваю мониторинг nginx, но zabbix отображает в латест дата только два параментра
Nginx: Number of processes nginx и Nginx: Memory allocated - их он получает с хоста на котором nginx, у автора же гораздо больше параметров, что я делаю не так ?
Нжинкс прикрутил, поехало норм все - огромное спасибо.
А вот апач наполовинку - графики не строятся, не получает данные для них. На сервере вручную все отрабатывает, подозреваю дело в пользователе битрикс, которого у меня нет на centos вм) Пробовал править xml шаблона, заменив пользователя на стандартного apache, но без изменений..
получает данные только для Apache: memory allocated и Apache: process count
Здравствуйте!
Пытаюсь настроить phpfpm и вот такая ошибка, почему не пойму, посоветуйте чьё делать
На консоле всё работает как написано в статье, только после подключение шаблона на Zabbix-е такие ошибки
Preprocessing failed for: {"pool":"www","process.manager":"dynamic","start.time":1588483802,"start.since":3897433,"accepted...
1. Failed: cannot extract value from json by path "$.accepted_conn": no data matches the specified path
Все зависимые элементы выдают такую ошибку
Вы шаблон какой используете? И какая версия Zabbix? Судя по всему вы используете какой-то новый шаблон, который парсит json вывод от phpfpm. У меня статья старая и там другой подход используется. Вам нужно шаблон брать из этой же статьи.
А как быть с версионностью php-fpm? Альтернативами тут явно не обойдешься.... Я про key
proc.num[php-fpm] и завязанный с ним тригер Template app php-fpm: Php-fpm services down
{server:proc.num[php-fpm].last()}=0 , я пока нашел только решение менять на proc.num[php-fpm$VER] --> например proc.num[php-fpm7.4]
У меня процессы называются php-fpm, хотя php версии 7.2, но вот их всё равно не считает и всегда тригерится событие с ошибкой "All system processes of php-fpm is down". Я понять не могу почему.
или вот такие сообщение
Value "HTTP/1.1 200 OK
Server: nginx
Date: Thu, 09 Apr 2020 14:13:00 GMT
Content-Type: text/plain
Content-Length: 119
Connection: close
Vary: Accept-Encoding
Active connections: 28
server accepts handled requests
5918320 5918320 46650597
Reading: 0 Writing: 56 Waiting: 24" of type "string" is not suitable for value type "Numeric (unsigned)"
Привет! Я так загрузил шаблон для мониторинга nginx, полсе несколько минут вот такие уведомления для нескольких 8 item-ов,
Value "" of type "string" is not suitable for value type "Numeric (unsigned)"
в чём может быть проблема?
А если у меня 1-5 посетителей в час, то триггеры будут срабатывать на каждого второго! (nginx)
Отключите их. Зачем вам вообще мониторинг в таком случае?
Мониторить на случай если будут атаковать! Обычно из-за этого.
Решил изменением триггера вот таким образом:
{Template App Nginx:nginx.active.connect.avg(600)}>{Template App Nginx:nginx.active.connect.avg(3600,600)}*3 and {Template App Nginx:nginx.active.connect.avg(3600)}> 10
Здравствуйте
Параметр Nginx: Latency с ключом system.run[curl -s -w %{time_total} -o /dev/null http://localhost/nginx-status%5D и
Nginx: Service response с ключом time net.tcp.service.perf[http,"{$NGINX.STUB_STATUS.HOST}","{$NGINX.STUB_STATUS.PORT}"] в родном шаблоне Zabbix 4.4.5
Одно и то же?!
Отклик в последнем 0,5-1 мс - слишком быстро. Первый - так и не настроил.
Нужен ping NGINX, PHP-FPM как у вас на последней картинке (так же было в старых шаблонах, сейчас не присоединяются - ошибка).
Нет. Все эти пинги очень условны. По сути это просто костыли, которые используют для измерения условной величины, значения которой трудно интерпретировать в реальную производительность. Все это сделано для того, чтобы просто отслеживать динамику изменений и сравнивать один сервер с другим. Главное, чтобы на них производились одинаковые измерения.
Выберите любую из этих метрик и используйте. Не принципиально, как конкретно вы будете мерить. В любом случае измерение через curl или что-то еще с консоли сервера к реальной нагрузке имеет очень отдаленное отношение.
То, что на картинке, было реализовано очень давно и сейчас я не использую. Но принципиально там нет ничего особенного. Использовался обычный curl запрос к localhost и измерялось время его исполнения через консольную же утилиту time.
Спасибо за ответ. Тогда не буду заморачиваться.
Спасибо за статью! Хочу поделиться скриптом и шаблоном для автоматического обнаружения пулов PHP-FPM и их дальнейшего мониторинга для Zabbix 4.0+ https://github.com/rvalitov/zabbix-php-fpm
Работает со всеми типам пулов (dynamic, static, ondemand), имеет все необходимые скрины и триггеры.
Надеюсь, что кому-нибудь это пригодится.
Спасибо, мне это актуально. У самого никак руки не доходили, так как вроде не сильно нужно, все время откладываю.
"Я так и не понял, как заставить агента ходить по ipv4. В итоге запустил nginx на обоих протоколах и разрешил забирать страницу статуса с адреса ::1. После этого заработало."
Была аналогичная проблема, показывал, что Nginx: Service is down, но, как ни странно, данные статуса выдавал. (Шаблон для NGINX встроенный в Zabbix 4.4).
В /etc/hosts закомментил локальный IPv6 и все заработало
#::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
Один из вариантов решения проблемы при использовании Zabbix 5 и шаблона по умолчанию "Template App Nginx by Zabbix agent" это заменить макрос $NGINX.STUB_STATUS.HOST на 127.0.0.1.
Этот вопрос так же обсуждался https://www.zabbix.com/forum/zabbix-help/404070-zabbix-agent-4-4-8-ipv6-bug
zabbix_agentd -t web.page.get[domain.example.com,nginx-status,443]
400 The plain HTTP request was sent to HTTPS port
400 Bad Request
The plain HTTP request was sent to HTTPS port
nginx
]
проблемы когда https сайт, что делать?
Отдавайте страницу со статусом по http. Тут https не нужен.
Добрый день, получаю вот такую ошибку когда заббикс агентом проверяю [t|HTTP/1.1 301 Moved Permanently, через веб, curl нормально все проходит. Как победить?
Так это не ошибка. У вас веб сервер на запрос отвечает 301-м кодом, что означает редирект. У вас так настроено. Разбирайтесь с конфигурацией nginx.
Curl же нормально возвращает же, почему через заббикс не может, он https не умеет редиректить?
Наверно заббикс агент не ходит по редиректам. Так отдайте ему страницу со статусом напрямую. Зачем там редирект?
А если на одном хосте много вирт хостов, как мониторить все?
В случае с php-fpm что бы агент не ломился на ipv6 помогло в UserParameter localhost заменить на 127.0.0.1
UserParameter=phpfpm.json[*],curl -s 'http://127.0.0.1/phpfpm-status?json' | tr ' ' _
Вы используете Bitrix VM или Debian/Centos?
Под сайты на bitrix всегда использую bitrixvm.
Полностью обновил и переработал статью. Теперь никаких скриптов. Все настройки на сервере мониторинга с помощью зависимых элементов.
Из статьи всё не работает в один клик, поэтому переписал и выкладываю рабочие решения.
Для nginx: https://pastebin.com/eLe5rfU3
Для php-fpm: https://pastebin.com/Udkta637
Не забываем, что для https нужно в curl использовать ключ "-k": ${CURL} -k ...
Автору спасибо за шаблоны и статью.
Спасибо, проверю. Как раз на днях надо будет настроить.
А шаблон можете скинуть или ссылку дать на него.
Они в статье лежат. Если браузер не хочет качать, то нужно в html код ссылки добавить какое-то слово, вроде download. Погуглите.
Статья с момента написания этого комментария полностью обновлена и переработана. Шаблоны в ней рабочие.
И еще такой вопрос.
При выполнение Template App Nginx by Alex Gluck: Get Nginx stat page: Nginx: requests per sec
Получаю : Cannot send request: wrong item type.
Это уже к автору шаблона и метода обращайтесь. Я не проверял этот шаблон.
Так же с любым другим итемом fpm. Данные не появляются в заббиксе.
На сервере с сайтом Ubuntu 16 установлен zabbix-agent и sender. При выполнение wget http://127.0.0.1/status
файл с данными создаётся. Скрипт создан при запуске его в ручную в /tmo/ c данными
real 0m0.013s
user 0m0.004s
sys 0m0.004s
В заббиксе к хосту теплейт прикрепил, но данных нет.
Подскажите не очень понимаю, скрипты должны лежать на сервере сайта или на сервере заббикса?
На сервере с nginx и php-fpm.
мониторинг nginx настроил по https://github.com/AlexGluck/ZBX_NGINX
а вот с php-fpm не допру что смотреть, подключение через fastcgi_pass 127.0.0.1:9000;
делаю проверку:
# wget http://127.0.0.1/status
--2019-03-26 12:52:51-- http://127.0.0.1/status
Connecting to 127.0.0.1:80... connected.
HTTP request sent, awaiting response... 502 Bad Gateway
2019-03-26 12:52:51 ERROR 502: Bad Gateway.
Смотрите лог ошибок nginx. У вас url http://127.0.0.1/status возвращает 502 ошибку. Что-то недонастроили.
не тот кофиг фпм правил. все почти получилось, но данные на сервер не поступают. но
cat /tmp/php-fpm-ping.tmp
real 0m0.007s
user 0m0.001s
sys 0m0.003s
разобрался. проблемы с сетью
Перестали получаться данные, только Php-fpm latency.
а так все выводит curl http://127.0.0.1/status
Данная статья писалась, когда в заббиксе не было зависимых элементов и предобработки данных. Сейчас мониторить nginx лучше вот так - https://github.com/AlexGluck/ZBX_NGINX Результат такой же, но более просто и удобно реализовано.
Шаблончик имеет небольшой недостаток - использует элемент данных траппер.
Поэтому, в случае, если данные перестанут достигать zabbix сервера, на графике
будет рисоваться горизонтальная линия на уровне последних данных, а не отсутствие линии.
помогает следующий финт ушами: замена элементов данных траппер на агент_активный,
и установка интервала в 2-3 раза больше интервала отправки данных (в нашем случае nginx.ping).
тогда в случае потери более 2-3 отсчетов линия перестанет отрисовываться,
и на графике появится видимый разрыв, соответствующий отсутствию данных.
доброго дня! подскажите, пожалуйста, - почему не отрабатывает nginx.ping :(
/usr/bin/curl --no-keepalive -s -m 9 -I http://127.0.0.1/nginx-status/
HTTP/1.1 301 Moved Permanently
Server: nginx
Date: Sat, 18 Feb 2017 14:46:16 GMT
Content-Type: text/html
Content-Length: 178
Connection: keep-alive
результат отработки скрипта:
cat /tmp/nginx-ping.tmp
real 0m0.005s
user 0m0.002s
sys 0m0.002s
wget в тоже время отрабатывает как следует:
cat nginx-status.2
Active connections: 79
server accepts handled requests
3487693 3487693 45939587
Reading: 0 Writing: 5 Waiting: 74
для curl при подключении по HTTPS надо указывать ключ -k :(
А вот что получилось для php-fpm:
1. я тоже отказался от использования time
2. у меня не работало с --assign, так что пришлось заменить --assign на -v
3. полагаю, что в вашем варианте была спец. защита, если sender вернет ошибку. У меня ее нет.
#!/bin/sh
PREFIX='php.fpm'
URL='http://127.0.0.1/status'
CURL='/usr/bin/curl'
SENDER='/usr/bin/zabbix_sender'
CONFIG='/etc/zabbix/zabbix_agentd.conf'
if [ ! -x ${CURL} ]
then echo Seems, path to curl is incorrect or not installed. && exit 0
else if [ ! -x ${SENDER} ]
then echo Seems, path to zabbix_sender is incorrect or not installed. && exit 0
else if [ ! -f ${CONFIG} ]
then echo Seems, path to zabbix_agentd.conf is incorrect && exit 0
fi fi fi
OUTPUT="$(${CURL} --no-keepalive -sm3 ${URL} -w 'ping: %{time_total}')"
echo "${OUTPUT}" | awk -v pr="- ${PREFIX}." '
/^accepted c/ {print pr"accepted_conn "$3}
/^active proc/ {print pr"active_processes "$3}
/^idle proc/ {print pr"idle_processes "$3}
/^listen queue:/ {print pr"listen_queue_len "$3}
/^max children reach/ {print pr"max_children_reached "$4}
/^max listen queue:/ {print pr"max_listen_queue_len "$4}' | ${SENDER} -c ${CONFIG} -i - >/dev/null 2>&1
echo "${OUTPUT}" | awk '/^ping:/ {print $2}' | sed 's/,/./'
exit 1
Вот такой код в итоге получился.
Из плюсов:
1. выше точность замеров пинга. У меня "пинг" упал с ~60мс до 1-6мс.
2. не требуется запуск time и создание временного файла.
#!/bin/bash
PREFIX='nginx'
URL='http://127.0.0.1/server-status'
CURL='/usr/bin/curl'
SENDER='/usr/bin/zabbix_sender'
CONFIG='/etc/zabbix/zabbix_agentd.conf'
if [ ! -x ${CURL} ]
then echo Seems, path to curl is incorrect or not installed. && exit 0
else if [ ! -x ${SENDER} ]
then echo Seems, path to zabbix_sender is incorrect or not installed. && exit 0
else if [ ! -f ${CONFIG} ]
then echo Seems, path to zabbix_agentd.conf is incorrect && exit 0
fi fi fi
read -a s <</dev/null 2>&1
echo ${s[16]/,/.}
else
echo '-0.001'
fi
exit 1
Тут похоже пропущен кусок кода
Здравствуйте.
1. Поймал такую ошибку:
root@dev02:/etc/zabbix/scripts# zabbix_get -s 127.0.0.1 -k nginx.ping
/etc/zabbix/scripts/nginx.sh: 19: /etc/zabbix/scripts/nginx.sh: Syntax error: redirection unexpected
Вылечилось заменой shebang с #!bin/sh на #!/bin/bash.
2. Лучше для пинга использовать не time, а, например, ключик curl -w %{time_total}, чтобы вывести не время запуска команды curl, а реальное время запроса-ответа.
Спасибо за дельные замечания.
Вам спасибо за хорошую работу! Осталось настроить php-fpm.
Вот здесь - http://doam.ru/fcgi_monitoring_with_zabbix/ более элегантное решение для мониторинга php-fpm.
Спасибо за информацию, посмотрю.