Дата последнего изменения: 03.07.2017
Итак, чтобы получать уведомления Nagios-а о различных событиях сервера, нужно настроить контакты и шаблон уведомлений:
/etc/nagios/objects/contacts.cfg
указываем параметр email
- email пользователя, кому будет отправляться нотификация:
define contact{ contact_name nagiosadmin ; Short name of user use generic-contact ; Inherit default values from generic-contact template (defined above) alias Nagios Admin ; Full name of user email email@myaddress.com ; <<***** CHANGE THIS TO YOUR EMAIL ADDRESS ****** }
/etc/nagios/objects/commands.cfg
меняем строки в секции SAMPLE NOTIFICATION COMMANDS
запуска MTA на:
# 'notify-host-by-email' command definition define command{ command_name notify-host-by-email command_line /usr/bin/printf "%b" "Subject: ** $NOTIFICATIONTYPE$ Host Alert: $HOSTNAME$ is $HOSTSTATE$ **\n\n ***** Nagios *****\n\nNotification Type: $NOTIFICATIONTYPE$\nHost: $HOSTNAME$\nState: $HOSTSTATE$\nAddress: $HOSTADDRESS$\nInfo: $HOSTOUTPUT$\n\nDate/Time: $LONGDATETIME$\n" | /usr/bin/msmtp --host=hostname --port=number --user=username --passwordeval=eval --from=mailfrom@email.com $CONTACTEMAIL$ } # 'notify-service-by-email' command definition define command{ command_name notify-service-by-email command_line /usr/bin/printf "%b" "Subject: ** $NOTIFICATIONTYPE$ Service Alert: $HOSTALIAS$/$SERVICEDESC$ is $SERVICESTATE$ **\n\n ***** Nagios *****\n\nNotification Type: $NOTIFICATIONTYPE$\n\nService: $SERVICEDESC$\nHost: $HOSTALIAS$\nAddress: $HOSTADDRESS$\nState: $SERVICESTATE$\n\nDate/Time: $LONGDATETIME$\n\nAdditional Info:\n\n$SERVICEOUTPUT$\n" | /usr/bin/msmtp --host=hostname --port=number --user=username --passwordeval=eval --from=mailfrom@email.com $CONTACTEMAIL$ }где:
--host=hostname
- адрес smtp-сервера; --port=number
- порт smtp-сервера; --user=username
- логин для авторизации на smtp-сервере; --passwordeval=eval
- пароль для авторизации на smtp-сервере; --from=mailfrom@email.com
- от кого будет уходить письмо. msmtp --help
.service nagios restart
Т.е, по сути, в конфигурационном файле Nagios мы меняем MTA с mail на msmtp c ключами и немного модифицируем текст сообщения: т.к у msmtp нет ключа Subject:
(Тема сообщения), то мы его включаем в тело письма, и оно при получении почтовым клиентом обработается корректно.
Проверить работу нотификаций можно, например, остановив МySQL:
service mysqld stop
По умолчанию Nagios будет записывать в лог 3 сообщения со статусом CRITICAL\SOFT каждую минуту, а 4-му сообщению даст статус CRITICAL\HARD. Далее будет инициирована команда notify-service-by-email, которая отправит текст сообщения через msmtp c ключами, настроенными выше. В итоге, в течение 4-5 минут сообщение примерно такого содержания должно уйти на почту:
Subject: ** PROBLEM Service Alert: test1/MySQL: connection to 3306 is CRITICAL ** ***** Nagios ***** Notification Type: PROBLEM Service: MySQL: connection to 3306 Host: server1 Address: 192.168.2.130 State: CRITICAL Date/Time: Tue Jan 27 20:15:15 MSK 2015 Additional Info: Connection refused
После запуска службы MySQL командой # service mysqld start
должно прийти сообщение на почту:
Subject: ** RECOVERY Service Alert: server1/MySQL: connection to 3306 is OK ** ***** Nagios ***** Notification Type: RECOVERY Service: MySQL: connection to 3306 Host: server1 Address: 192.168.2.130 State: OK Date/Time: Wed Jan 28 12:30:50 MSK 2015 Additional Info: TCP OK - 0.001 second response time on port 3306