环境介绍>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
服务端(监控端):192.168.100.2     --nagios服务+check_nrpe
客户端(被监控端):192.168.100.3    --nrpe守护进程+检测插件

Nagios通过NRPE来远端管理服务的过程
1. Nagios服务端执行安装在它里面的check_nrpe插件,并告诉check_nrpe 去检测哪些服务。
2. 通过SSL,check_nrpe连接远端机子上的NRPE daemon
3. 被监控端的NRPE运行本地的各种插件去检测本地的服务和状态(check_disk,..etc)
4. 最后,被监控端的的NRPE把检测的结果传给nagios服务端的check_nrpe,check_nrpe再把结果送到Nagios状态队列中。
5. Nagios 依次读取队列中的信息,再把结果显示出来。

NRPE 工作原理如下图所示:

NRPE 总共由两部分组成:
1、check_nrpe 插件,位于监控主机上
2、NRPE daemon,运行在远程的Linux主机上(通常就是被监控机)

当Nagios 需要监控某个远程Linux 主机的服务或者资源情况时:
Nagios 会运行check_nrpe 这个插件,告诉它要检查什么;
check_nrpe 插件会连接到远程的NRPE daemon,所用的方式是SSL;
NRPE daemon会运行相应的Nagios插件来执行检查;
NRPE daemon将检查的结果返回给check_nrpe 插件,插件将其递交给nagios做处理。
注意:NRPE daemon需要Nagios 插件安装在远程的Linux主机上,否则,daemon不能做任何的监控。

服务端(监控端)安装过程 

1、服务端需要先安装nagios服务,安装方法可点击笔者的另一篇文章,《linux系统下Nagios+rrdtool+Pnp4nagios监控环境的搭建》

2、安装nrpe所需的依赖,使用yum命令安装即可。

[root@nagios_server ~]# yum install gcc make -y
[root@nagios_server ~]# yum install openssl-devel -y //check_nrpd会通过ssl的方式,连接远端的NRPE Daemon

3、解压nrpe-2.15.tar.gz,进入其目录,执行如下命令。

[root@nagios_server nrpe-2.15]# ./configure --with-nrpe-user=nagios    //可以就以nagios用户运行nrpe,如没有此用户,须先创建
[root@nagios_server nrpe-2.15]# make all //编译所有源码
[root@nagios_server nrpe-2.15]# make install-plugin //安装check_nrpe插件,默认为安装到/usr/local/nagios/libexec目录

客户端(被监控端)的安装过程 

1、安装nrpe所需的依赖,使用yum命令安装即可。

[root@nagios_server ~]# yum install gcc make -y
[root@nagios_server ~]# yum install openssl-devel -y //check_nrpd会通过ssl的方式,连接远端的NRPE Daemon

2、解压nrpe-2.15.tar.gz,进入其目录,执行如下命令:

[root@nagios_client ~]# useradd nagios                                   //创建nagios用户
[root@nagios_server nrpe-2.15]# ./configure --with-nrpe-user=nagios //可以就以nagios用户运行nrpe
[root@nagios_client nrpe-2.15]# make all //编译所有源码
[root@nagios_client nrpe-2.15]# make install-daemon //安装nrpe命令,默认安装到/usr/local/nagios/bin目录
[root@nagios_client nrpe-2.15]# make install-daemon-config //安装nrpe配置文件,默认安装到/usr/local/nagios/etc目录

3、修改nrpe.cfg配置文件,允许监控端通过check_nrpe进行连接nrpe守护进程,默认只允许本机,加上监控端的IP即可。

allowed_hosts=127.0.0.1,192.168.100.2

4、启动nrpe守护进程,也可以将如下命令加入到开机启动脚本/etc/rc.local

[root@nagios_client nrpe-2.15]# /usr/local/nagios/bin/nrpe -c /usr/local/nagios/etc/nrpe.cfg -d    //启动nrpe,监听TCP 5666 端口

5、验证是否安装及启动成功,可在服务端执行如下命令:

[root@nagios_server libexec]# /usr/local/nagios/libexec/check_nrpe -H 192.168.100.3                 //显示被监控端nrpe的版本
[root@nagios_server libexec]# /usr/local/nagios/libexec/check_nrpe -H 192.168.100.3 -c check_load //通过nrpe执行远端的检测插件

这里需要特别注意的有2点

(1)被监控端必须得有有/usr/local/nagios/libexec/check_load 检测脚本文件

(2)通过check_nrpe 命令后的-c参数所接的命令名是被定义在监控端的nrpe.cfg中,如下图所示:

服务端(监控端)的配置

1、定义命令,在/usr/local/nagios/etc/objects/commands.cfg中增加对check_nrpe的定义,加入如下内容:

define command{
command_name check_nrpe //定义命令名称为check_nrpe,在services.cfg中要使用这个名称.
command_line $USER1$/check_nrpe -H $HOSTADDRESS$ -c $ARG1$ //这是定义实际运行的插件程序
}

-c后的$ARG1$参数是传给nrpe daemon执行的检测命令,它必须是nrpe.cfg中所定义的那几条命令中的一条。在定义监控服务中使用check_nrpe的时候要用!带上这个参数

2、在/usr/local/nagios/etc/nagios.cfg配置文件中加上如下内容:

cfg_file=/etc/nagios/objects/linux.cfg                           //让nagios包含此配置文件

3、定义主机与check_nrpe要检测的远端command名字。这里我们可以将主机与服务写在一个文件里,创建/usr/local/nagios/etc/objects/linux.cfg文件,写入如下内容:

define host{
use linux-server
host_name nagios_client //nagios网页上的主机名
address 192.168.100.3
}
define service{
use local-service
host_name nagios_client
service_description cpu_load //nagios网页上的服务名
check_command check_nrpe!check_load
normal_check_interval //检测的间隔
}

4、重启nagios服务。打开nagios监控网站,可见如下图所示,则表示被监控节点添加成功。

关于Nagios通过NRPE监控客户端的安装与配置的更多相关文章

  1. Oracle 11g 客户端的安装和配置。

    原文:Oracle 11g 客户端的安装和配置. 数据库和客户端在不同的机器之上. 在安装之前,在安装Oracle数据库的服务器上导航到下面的目录. 将listener.ora和tnsnames.or ...

  2. Git客户端的安装与配置入门

    GitLab与Git客户端的安装与配置入门,每次配置完一段时间,就忘记配置过程了,为了自己和同学们以后有所参照,特记录了本次下载和配置,其实Git就是一个版本控制系统,类似于SVN,CVS等 下载:W ...

  3. nagios系列(二)之nagios客户端的安装及配置

    1.添加nagios用户 echo "------ step 1: add nagios user------" #create user group /usr/sbin/user ...

  4. Nagios学习笔记一:基本安装和配置

    ()解决安装Nagios的依赖关系: Nagios基本组件的运行依赖于httpd.gcc和gd.可以通过以下命令来检查nagios所依赖的rpm包是否已经完全安装: # yum -y install ...

  5. linux之 NFS服务器与客户端的安装与配置

    今天实验室需要搭建NAS,我负责的是NFS的安装与配置,现将整理的文档分享一下: 参考一:Linux下rpm 安装包方式安装 http://linux.chinaunix.net/techdoc/be ...

  6. Oracle Client(客户端) 安装与配置

    因为工作需要,需要通过本地oracle客户端将数据导入到远程服务器上的oracle数据库中.从csdn下了很多oracle客户端,都是属于精简版,缺少imp.exe文件,造成无法导入数据.所以最终从o ...

  7. Oracle Instant Client(即时客户端) 安装与配置

    一.下载 下载地址:http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html 这是Ora ...

  8. FTP服务器与客户端的安装与配置

    FTP服务器安装与配置 1. 切换到root用户:  su root 2. 查看系统中是否安装了vsftpd,可以通过执行命令 :  rpm -qa | grep vsftpd 3. 如果没有安装 v ...

  9. Prometheus 系统监控方案 二 安装与配置

    下载Prometheus 下载最新安装包,本文说的都是在Linux x64下面内容,其它平台没尝试过,请选择合适的下载. Prometheus 主程序,主要是负责存储.抓取.聚合.查询方面. Aler ...

随机推荐

  1. useradd groupadd passwd usermod userdel chfn id

    chfn   修改用户信息 id 显示当前用户和用户组的id

  2. 给NSMutableArray添加copy属性就变成了NSArray

    -copy, as implemented by mutable Cocoa classes, always returns their immutable counterparts. Thus, w ...

  3. vue实现文章内容过长点击阅读全文功能

    直接上代码: html: <div class="bodyFont clearfloat" id="bodyFont" ref="bodyFon ...

  4. Nine-patch

    http://developer.android.com/guide/topics/graphics/2d-graphics.html#nine-patch   This NinePatch defi ...

  5. 超分辨率论文CVPR-Kai Zhang

    深度学习与传统方法结合的超分辨率:Kai Zhang 1. (CVPR, 2019) Deep Plug-and-Play Super-Resolution for Arbitrary https:/ ...

  6. eclipse 生成webservice 客户端

    一.eclipse 自动生成的web客户端代码 调用客户端

  7. Android数据库升级、降级、创建(onCreate() onUpgrade() onDowngrade())的注意点

    以下内容可以作为面试官在面试的时候的问题,感觉比较好,是比较常用的知识点,可以用来考察基础是否扎实. 也可以程序猿学习.开发中的注意点.因为稍微不注意,就有可能导致数据库不能用. DBAdapter. ...

  8. ant 打批量渠道包,第三方项目作为library打包出错的问题

    ant批量打包不解释了.详情请看前面其它的blog! 这里说一下 开发中,非常可能遇到引用第三方的项目作为library情况.这样的情况下该怎么打包呢? 第一:改动build.xml 第二:在init ...

  9. Java Jdk1.8 HashMap源代码阅读笔记二

    三.源代码阅读 3.元素包括containsKey(Object key) /** * Returns <tt>true</tt> if this map contains a ...

  10. Dubbo -- 系统学习 笔记 -- 示例 -- 结果缓存

    Dubbo -- 系统学习 笔记 -- 目录 示例 想完整的运行起来,请参见:快速启动,这里只列出各种场景的配置方式 结果缓存 结果缓存,用于加速热门数据的访问速度,Dubbo提供声明式缓存,以减少用 ...