共计 5142 个字符,预计需要花费 13 分钟才能阅读完成。
在先前的教程中(http://www.linuxidc.com/Linux/2014-10/108535.htm),我们已经见到了如何在 Nagios 设置中设置 Nagios 远程执行插件(NRPE)。然而,监控内存使用率的脚本和插件并没有在原生的 Nagios 中。本篇中,我们会看到如何配置 NRPE 来监控远程服务器上的内存使用率。
我们要用的监控内存的脚本在 Nagios 市场上,在创建者的 Github 仓库中也可以找到。
假设我们已经安装了 NRPE,我们首先在我们想要监控的服务器上下载脚本。
网络监控器 Nagios 全攻略 http://www.linuxidc.com/Linux/2013-07/87067.htm
Nagios 搭建与配置详解 http://www.linuxidc.com/Linux/2013-05/84848.htm
Nginx 环境下构建 Nagios 监控平台 http://www.linuxidc.com/Linux/2011-07/38112.htm
在 RHEL5.3 上配置基本的 Nagios 系统 (使用 Nagios-3.1.2) http://www.linuxidc.com/Linux/2011-07/38129.htm
CentOS 5.5+Nginx+Nagios 监控端和被控端安装配置指南 http://www.linuxidc.com/Linux/2011-09/44018.htm
Ubuntu 13.10 Server 安装 Nagios Core 网络监控运用 http://www.linuxidc.com/Linux/2013-11/93047.htm
准备远程服务器
在 Debain/Ubuntu 中:
- # cd /usr/lib/nagios/plugins/
- # wget https://raw.githubusercontent.com/justintime/nagios-plugins/master/check_mem/check_mem.pl
- # mv check_mem.pl check_mem
- # chmod +x check_mem
在 RHEL/CentOS 中:
- # cd /usr/lib64/nagios/plugins/ (or /usr/lib/nagios/plugins/ for 32-bit)
- # wget https://raw.githubusercontent.com/justintime/nagios-plugins/master/check_mem/check_mem.pl
- # mv check_mem.pl check_mem
- # chmod +x check_mem
你可以通过手工在本地运行下面的命令来检查脚本的输出是否正常。当使用 NRPE 时,这条命令应该会检测空闲的内存,当可用内存小于 20% 时会发出警告,并且在可用内存小于 10% 时会生成一个严重警告。
- # ./check_mem -f -w 20 -c 10
- OK –34.0%(2735744 kB) free.|TOTAL=8035340KB;;;; USED=5299596KB;6428272;7231806;; FREE=2735744KB;;;; CACHES=2703504KB;;;;
如果你看到像上面那样的输出,那就意味这命令正常工作着。
现在脚本已经准备好了,我们要定义 NRPE 检查内存使用率的命令了。如上所述,命令会检查可用内存,在可用率小于 20% 时发出警报,小于 10% 时发出严重警告。
- # vim /etc/nagios/nrpe.cfg
对于 Debian/Ubuntu:
- command[check_mem]=/usr/lib/nagios/plugins/check_mem –f –w 20–c 10
对于 RHEL/CentOS 32 bit:
- command[check_mem]=/usr/lib/nagios/plugins/check_mem –f –w 20–c 10
对于 RHEL/CentOS 64 bit:
- command[check_mem]=/usr/lib64/nagios/plugins/check_mem –f –w 20–c 10
更多详情见请继续阅读下一页的精彩内容 :http://www.linuxidc.com/Linux/2014-11/108859p2.htm
准备 Nagios 服务器
在 Nagios 服务器中,我们为 NRPE 定义了一条自定义命令。该命令可存储在 Nagios 内的任何目录中。为了让本教程简单,我们会将命令定义放在 /etc/nagios 目录中。
对于 Debian/Ubuntu:
- # vim /etc/nagios3/conf.d/nrpe_command.cfg
- define command{
- command_name check_nrpe
- command_line /usr/lib/nagios/plugins/check_nrpe –H ‘$HOSTADDRESS$’–c ‘$ARG1$’
- }
对于 RHEL/CentOS 32 bit:
- # vim /etc/nagios/objects/nrpe_command.cfg
- define command{
- command_name check_nrpe
- command_line /usr/lib/nagios/plugins/check_nrpe –H $HOSTADDRESS$ –c $ARG1$
- }
对于 RHEL/CentOS 64 bit:
- # vim /etc/nagios/objects/nrpe_command.cfg
- define command{
- command_name check_nrpe
- command_line /usr/lib64/nagios/plugins/check_nrpe –H $HOSTADDRESS$ –c $ARG1$
- }
现在我们定义 Nagios 的服务检查
在 Debian/Ubuntu 上:
- # vim /etc/nagios3/conf.d/nrpe_service_check.cfg
- define service{
- uselocal–service
- host_name remote–server
- service_description Check RAM
- check_command check_nrpe!check_mem
- }
在 RHEL/CentOS 上:
- # vim /etc/nagios/objects/nrpe_service_check.cfg
- define service{
- uselocal–service
- host_name remote–server
- service_description Check RAM
- check_command check_nrpe!check_mem
- }
最后我们重启 Nagios 服务
在 Debian/Ubuntu 上:
- # service nagios3 restart
在 RHEL/CentOS 6 上:
- # service nagios restart
在 RHEL/CentOS 7 上:
- # systemctl restart nagios.service
故障排除
Nagios 应该开始在使用 NRPE 的远程服务器上检查内存使用率了。如果你有任何问题,你可以检查下面这些情况。
- 确保 NRPE 的端口在远程主机上是总是允许的。默认 NRPE 的端口是 TCP 5666。
- 你可以尝试通过执行 check_nrpe 命令:/usr/lib/nagios/plugins/check_nrpe -H remote-server 手工检查 NRPE 操作。
- 你同样可以尝试运行 check_mem 命令:/usr/lib/nagios/plugins/check_nrpe -H remote-server –c check_mem
- 在远程服务器上,在 /etc/nagios/nrpe.cfg 中设置 debug=1。重启 NRPE 服务并检查这些日志文件,/var/log/messages (RHEL/CentOS) 或者 /var/log/syslog (Debain/Ubuntu)。如果有任何的配置或者权限错误,日志中应该包含了相关的信息。如果日志中没有反映出什么,很有可能是由于请求在某些端口上有过滤而没有到达远程服务器上。
总结一下,这边教程描述了我们该如何调试 NRPE 来监控远程服务器的内存使用率。过程只需要下载脚本、定义命令和重启服务就行了。希望这对你们有帮助。
Nagios 的详细介绍 :请点这里
Nagios 的下载地址 :请点这里
在先前的教程中(http://www.linuxidc.com/Linux/2014-10/108535.htm),我们已经见到了如何在 Nagios 设置中设置 Nagios 远程执行插件(NRPE)。然而,监控内存使用率的脚本和插件并没有在原生的 Nagios 中。本篇中,我们会看到如何配置 NRPE 来监控远程服务器上的内存使用率。
我们要用的监控内存的脚本在 Nagios 市场上,在创建者的 Github 仓库中也可以找到。
假设我们已经安装了 NRPE,我们首先在我们想要监控的服务器上下载脚本。
网络监控器 Nagios 全攻略 http://www.linuxidc.com/Linux/2013-07/87067.htm
Nagios 搭建与配置详解 http://www.linuxidc.com/Linux/2013-05/84848.htm
Nginx 环境下构建 Nagios 监控平台 http://www.linuxidc.com/Linux/2011-07/38112.htm
在 RHEL5.3 上配置基本的 Nagios 系统 (使用 Nagios-3.1.2) http://www.linuxidc.com/Linux/2011-07/38129.htm
CentOS 5.5+Nginx+Nagios 监控端和被控端安装配置指南 http://www.linuxidc.com/Linux/2011-09/44018.htm
Ubuntu 13.10 Server 安装 Nagios Core 网络监控运用 http://www.linuxidc.com/Linux/2013-11/93047.htm
准备远程服务器
在 Debain/Ubuntu 中:
- # cd /usr/lib/nagios/plugins/
- # wget https://raw.githubusercontent.com/justintime/nagios-plugins/master/check_mem/check_mem.pl
- # mv check_mem.pl check_mem
- # chmod +x check_mem
在 RHEL/CentOS 中:
- # cd /usr/lib64/nagios/plugins/ (or /usr/lib/nagios/plugins/ for 32-bit)
- # wget https://raw.githubusercontent.com/justintime/nagios-plugins/master/check_mem/check_mem.pl
- # mv check_mem.pl check_mem
- # chmod +x check_mem
你可以通过手工在本地运行下面的命令来检查脚本的输出是否正常。当使用 NRPE 时,这条命令应该会检测空闲的内存,当可用内存小于 20% 时会发出警告,并且在可用内存小于 10% 时会生成一个严重警告。
- # ./check_mem -f -w 20 -c 10
- OK –34.0%(2735744 kB) free.|TOTAL=8035340KB;;;; USED=5299596KB;6428272;7231806;; FREE=2735744KB;;;; CACHES=2703504KB;;;;
如果你看到像上面那样的输出,那就意味这命令正常工作着。
现在脚本已经准备好了,我们要定义 NRPE 检查内存使用率的命令了。如上所述,命令会检查可用内存,在可用率小于 20% 时发出警报,小于 10% 时发出严重警告。
- # vim /etc/nagios/nrpe.cfg
对于 Debian/Ubuntu:
- command[check_mem]=/usr/lib/nagios/plugins/check_mem –f –w 20–c 10
对于 RHEL/CentOS 32 bit:
- command[check_mem]=/usr/lib/nagios/plugins/check_mem –f –w 20–c 10
对于 RHEL/CentOS 64 bit:
- command[check_mem]=/usr/lib64/nagios/plugins/check_mem –f –w 20–c 10
更多详情见请继续阅读下一页的精彩内容 :http://www.linuxidc.com/Linux/2014-11/108859p2.htm