本文出自 “曹坏水” 博客,请务必保留此出处http://cao2012.blog.51cto.com/366908/1132113

NRPE是Nagios的一个功能扩展,它可在远程Linux和UNIX主机上执行插件程序。通过在远程服务器上安装NRPE构件及Nagios插件程序来向Nagios监控平台提供该服务器的一些本地情况,如CPU负载、内存使用、硬盘使用等。这里将Nagios监控平台称为Nagios服务器端,而将远程被监控的服务器称为Nagios客户端。

下图为NRPE构件监控远程主机本地信息的运行原理:

NRPE总共由两部分组成:

--check_nrpe插件,位于监控主机上

--NRPE daemon,运行在远程被监控的Linux主机上

当监控远程Linux/UNIX主机服务或资源时,流程如下:

1、nagios会运行check_nrpe这个插件,并且会告诉它需要检查什么;

2、check_nrpe插件会连接到远程的NRPE daemon,所用的方式是SSL;

3、NRPE daemon会运行相应的nagios插件来执行检查动作;

4、NPRE daemon将检查的结果返回给check_nrpe插件,插件将其递交给nagios做处理。

注意:NRPE daemon需要nagios插件安装在远程的Linux主机上,否则daemon不能做任何的监控。

通过NRPE的检测分为两种:

1)直接检测:检测的对象是运行NRPE的那台Linux主机的本地资源,原理如下:

直接使用NRPE插件监控远程Linux/UNIX主机的本地或者私有资源。例如:CPU负载,内存使用,SWAP空间使用,硬盘等运行状况。

2)间接检测:当运行Nagios的监控主机无法访问到某台被监控主机,但是运行NRPE的机器可以访问得到的时候,运行NRPE的主机就充当一个中间代理,将监控请求发送到被监控对象上。

其实这种情况一般出现在监控主机与被监控主机不在同一段网络内。日常企业里一般不非出现这样情况,所以下面我所做的都是直接检测。

Nagios监控客户端的安装

添加用户名

[root@testdb ~]# useradd -s /sbin/nolgin nagios

安装Nagios的插件nagios-plugin

[root@Nagios ~]# tar -zxvf nagios-plugins-1.4.16.tar.gz

[root@testdb ~]# cd nagios-plugins-1.4.16

[root@testdb nagios-plugins-1.4.16]# ./configure

注意:如果你 RedHat AS4 版本的服务器要添加--enable-redhat-pthread-workaround 选项。

[root@testdb nagios-plugins-1.4.16]# make && make install
 
安装NRPE
[root@testdb ~]# tar zxvf nrpe-2.13.tar.gz 
[root@testdb ~]# cd nrpe-2.13
[root@testdb nrpe-2.13]# ./configure
输出下图的结果:

可以从上图中看出NRPE的端口是5666

下一步是make all,输出如下图截图所示:

安装check_nrpe插件

[root@testdb nrpe-2.13]# make install-plugin

其实被监控机不需要安装这个插件,这里我只是为测试!
安装deamon
[root@testdb nrpe-2.13]#make install-daemon
安装配置文件
[root@testdb nrpe-2.13]#make install-daemon-config
将NRPE deamon作为xinetd下的一个服务运行,在这个情况下xinetd就必须先安装好,一般系统都会默认安装了。
安装xinetd脚本
[root@testdb nrpe-2.13]#make install-xinetd
配置NRPE
[root@testdb ~]#vi /etc/xinetd.d/nrpe

#注意:在only_from添加Nagios监控服务器的IP地址。修改后如上图所示!

添加服务端口

[root@testdb ~]#vi /etc/services

#在文件末尾添加

nrpe 5666/tcp

重启服务并验证安装

[root@testdb ~]#/etc/init.d/xinetd restart

[root@testdb ~]# netstat -at|grep nrpe

tcp        0      0 *:nrpe                      *:*                         LISTEN

[root@testdb ~]# netstat -an|grep 5666

tcp        0      0 0.0.0.0:5666                0.0.0.0:*                   LISTEN

修改权限
[root@testdb ~]# chown -R nagios:nagios /usr/local/nagios/
测试NRPE是否正常工作
前面安装了check_nrpe这个插件用于测试,现在就是用的时候,执行
/usr/local/nagios/libexec/check_nrpe -H localhost,如下图所示:

也就是在本地用check_nrpe连接nrpe daemon是正常的。

/usr/local/nagios/libexec/check_nrpe –h查看这个命令的用法
可以看到用法是check_nrpe –H 被监控的主机 -c要执行的监控命令
注意:-c后面接的监控命令必须是nrpe.cfg文件中定义的.也就是NRPE daemon只运行nrpe.cfg中所定义的命令。
 
修改Nagios客户端NRPE的配置文件,如下图所示:

由于-c后面只能接nrpe.cfg中定义的命令,也就是说现在我们只能用上面定义的这五条命令.我们可以在本机实验一下.如下图所示:

Nagios服务器的部署

安装NRPE

[root@Nagios ~]# cd /usr/local/src/

[root@Nagios src]# tar zxvf nrpe-2.13.tar.gz

[root@Nagios src]# cd nrpe-2.13

[root@Nagios nrpe-2.13]# ./configure && make all

[root@Nagios nrpe-2.13]# make install-plugin

[root@Nagios nrpe-2.13]# make install-daemon

[root@Nagios nrpe-2.13]# make install-daemon-config

[root@Nagios nrpe-2.13]# make install-xinetd

配置NRPE

[root@Nagios ~]# vi /etc/xinetd.d/nrpe 如下图示:

#注意:在only_from添加要监控的主机IP地址,中间以空格隔开。
 
添加服务端口 
 
[root@Nagios ~]# vi /etc/services
#在文件末尾添加,如果不添加端口,nrpe 将不能正常运行
nrpe 5666/tcp #nrpe
[root@Nagios~]# /etc/init.d/xinetd restart
[root@Nagios ~]# netstat -na | grep 5666
tcp 0 0 0.0.0.0:5666 0.0.0.0:*
 
修改命令定义文件
 
由于命令定义文件里默认没有 check_nrpe 命令,所以需要先定义后使用。
[root@Nagios ~]# vim /usr/local/nagios/etc/objects/commands.cfg
#nrpe set 在文件末尾添加下面命令定义
define command{
command_name check_nrpe
command_line /usr/local/nagios/libexec/check_nrpe -H $HOSTADDRESS$ -c $ARG1$
}
 
修改Nagios服务器hosts.cfg和services.cfg文件,如下图所示:
hosts.cfg

services.cfg:

登陆验证配置

查看配置文件是否正确

[root@Nagios ~]# /usr/local/nagios/bin/nagios -v /usr/local/nagios/etc/nagios.cfg

重新加载配置文件

[root@Nagios ~]# /etc/init.d/nagios reload

用 浏览器登陆验证,如下图所示:

#这篇文章是根据Nagios官方文档和网上一些资料撰写的!附件已上传。

Nagios的安装配置与应用之五监控远程Linux服务器的更多相关文章

  1. jprofiler_监控远程linux服务器的JVM进程(实践)

    几天前写了一篇文章,jprofiler_监控远程linux服务器的tomcat进程(实践),介绍了使用jprofiler怎样监控远程linux的tomcat进程,这两天想了想,除了可以监控tomcat ...

  2. jprofiler_监控远程linux服务器的JVM进程(转 非常棒)

    几天前写了一篇文章,jprofiler_监控远程linux服务器的tomcat进程(实践),介绍了使用jprofiler怎样监控远程linux的tomcat进程,这两天想了想,除了可以监控tomcat ...

  3. 搭建基于Nagios的监控系统——之监控远程Linux服务器

    上一篇介绍了如何安装Nagios Core,这一篇跟大家分享一下如何将一台远程的Linux服务器加入纳入监控范围. 第一部分:在远程Linux上安装Nagios Plugins和NRPE   第一步: ...

  4. jprofiler_监控远程linux服务器的tomcat进程(实践)

    一.软件列表: windows和linux的jprofiler的版本必须一致 1.jprofiler_linux_9_1_1.tar.gz 2.jprofiler_windows_x64 9_1_1 ...

  5. nagios的安装配置

    主要参考博客:http://www.cnblogs.com/mchina/archive/2013/02/20/2883404.html 实验环境:centos6.4     最小化安装系统 **** ...

  6. Nagios学习笔记四:基于NRPE监控远程Linux主机

    1.NRPE简介 Nagios监控远程主机的方法有多种,其方式包括SNMP.NRPE.SSH和NCSA等.这里介绍其通过NRPE监控远程Linux主机的方式. NRPE(Nagios Remote P ...

  7. 阿里云服务器Linux CentOS安装配置(一)购买阿里云服务器

    阿里云服务器Linux CentOS安装配置(一)购买阿里云服务器 我在阿里云购买的服务器配置 CPU:1核 内存:2G 系统盘:40G 公共镜像:CentOS 6.5 64位 公网带宽:1Mbps ...

  8. Jvisualvm监控远程linux下Tomcat

    Jvisualvm监控远程linux下Tomcat 1.编辑tomcat/bin/catalina.sh 加入下面这段代码,中间无换行: CATALINA_OPTS="$CATALINA_O ...

  9. 搭建基于Nagios的监控系统——之监控远程Windows服务器

    分享了如何监控Linux服务器,我们来看看使用Nagios如何监控Windows服务器. 第一部分:配置被监控的Windows服务器   首先,访问 http://sourceforge.net/pr ...

随机推荐

  1. Linux命令(4):cat命令

    1.作用:连接并显示指定的一个和多个文件的有关信息: 2.格式:cat [选项] 文件1 文件2 ... 其中文件1.文件2为要显示的多个文件: 3.常见参数: 4.使用实例: [youname@ww ...

  2. jQuery 笔记

    1. 选择器  http://www.runoob.com/jquery/jquery-selectors.html 2. toggle()  用来切换 hide() 和 show() 方法   ht ...

  3. MLlearning(1)——kNN算法

    这篇文章讲kNN(k近邻,k-Nearest Neighbour).这是一种lazy-learning,实现方便,很常用的分类方法.约定n为样本集中的样本数,m为样本的维度,则这个算法的训练复杂度为0 ...

  4. 20141015--for语句1

    for 语句 break (跳出循环体) 100节楼梯,第1-49节分数等于节数,50以后(包括50)每节10分,

  5. JavaScript的语法规则

    JavaScript的语法规则 JavaScript区分大小写 JavaScript脚本程序须嵌入在HTML文件中 JavaScript脚本程序中不能包含HTML标记代码 每行写一条脚本语句 语句末尾 ...

  6. oracle手动启动服务

    开始-控制面板->管理工具->服务->右键属性 oracle服务设定都是手动启动的,开机时只需要启动3个服务就好了: OracleOraDb11g_home1ClrAgent Ora ...

  7. pthread 实现生产者消费者问题

    经典的生产者消费者问题,在这里用信号量和互斥量来实现生产和消费者模型   #include<cstdlib> #include<cstdio> #include<unis ...

  8. Windows内存原理与内存管理

    WIndows为每个进程分配了4GB的虚拟地址空间,让每个进程都认为自己拥有4GB的内存空间,4GB怎么来的? 32位 CPU可以取地址的空间为2的32次方,就是4GB(正如16位CPU有20根寻址线 ...

  9. 利用HibernateTools从数据库表生成带注解的POJO

    在SSH框架中,如果先设计好了数据库,那么下一步就需要从数据库Table生成实体java类和hbm.xml配置文件.在最新的开发框架中,已经支持使用注解,从而避免了繁琐的hbm.xml配置,而且我们可 ...

  10. DTCMS规格统一赋值

    admin\article_edit.aspx 已经存在 市场价格 和销售价格统一赋值 //赋值规格市场价格 $("#field_control_market_price").bl ...