Назад | Перейти на главную страницу

nagios nrpe не может прочитать вывод

Я пытаюсь использовать check_nrpe чтобы проверить удаленный сервер, но он не работает, и я не могу понять, что мне не хватает ...

# /usr/lib/nagios/plugins/check_nrpe -H XXX -c check_load -a 6,5,4 8,7,6
NRPE: Unable to read output
# 

Сообщение системного журнала удаленного сервера:

nrpe[18058]: Connection from XX.XX.XX.XX port 16267
nrpe[18058]: Host address is in allowed_hosts
nrpe[18058]: Handling the connection...
nrpe[18058]: Host is asking for command 'check_load' to be run...
nrpe[18058]: Running command: /usr/bin/sudo /usr/lib64/nagios/plugins/check_load -w 6,5,4 -c 8,7,6
nrpe[18058]: Command completed with return code 1 and output: 
nrpe[18058]: Return Code: 1, Output: NRPE: Unable to read output
nrpe[18058]: Connection from XX.XX.XX.XX closed.

чтобы проверить это вручную, я запускаю ту же команду в удаленной оболочке:

bash-4.1$ id
uid=497(nrpe) gid=497(nrpe) groups=497(nrpe) context=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023
bash-4.1$ /usr/bin/sudo /usr/lib64/nagios/plugins/check_load -w 6,5,4 -c 8,7,6
OK - load average: 0.21, 0.23, 0.19|load1=0.210;6.000;8.000;0; load5=0.230;5.000;7.000;0; load15=0.190;4.000;6.000;0; 
bash-4.1$ 

... проблема была, хотя nrpe_user Внутри /etc/nagios/nrpe.cfg был установлен на nrpe, для любой причины nrpe работал как nagios пользователь, поэтому мне пришлось перенастроить sudoers.d файл, и он сразу начинает работать ...

# grep nrpe_user /etc/nagios/nrpe.cfg
nrpe_user=nrpe
# ps auxwww | grep nrpe
nagios   25388  0.0  0.0  41332  1240 ?        Ss   11:32   0:00 /usr/sbin/nrpe -c /etc/nagios/nrpe.cfg -d
root     26230  0.0  0.0 103252   828 pts/3    S+   11:47   0:00 grep nrpe
# cat /etc/sudoers.d/01_nagios 
Defaults:nagios !requiretty
nagios      ALL=(ALL)   NOPASSWD:   /usr/lib64/nagios/plugins/
# 

Это может быть вызвано настройкой sudo "requiretty". Однако настоящий вопрос заключается в том, почему вы все равно запускаете check_load через sudo.

Итак, чтобы исправить это: либо отключите requiretty (только для пользователя nagios / nrpe), либо прекратите запуск плагина через sudo.

На проверяемой машине найдите файл nrpe.cfg и внутри него запись для "check_load". Это будет выглядеть примерно так:

command[check_load]=/usr/lib64/nagios/plugins/check_load -w 15,10,5 -c 30,25,20

Попробуйте выполнить команду на этом компьютере - все, что находится справа от знака равенства выше, и посмотрите, что вы получите.

/usr/lib64/nagios/plugins/check_load -w 15,10,5 -c 30,25,20

Готов поспорить, он ищет check_load в / usr / lib / nagios / plugins вместо / usr / lib64 или что-то в этом роде.