nagios:一个监视系统的框架。它用来集成各种监听服务的插件来实现对从属机的监听。

原理:

nagios通过周期性的自动调用插件去检查从属机器的状态,在此同时会创建一个队列,将返回的消息状态放入到队列中,然后通过web界面显示出来。


主要功能:

  1. 网络服务监控(SMTP、POP3、HTTP、NNTP、ICMP、SNMP、FTP、SSH)
  2. 主机资源监控(CPU load、disk usage、system logs),也包括Windows主机(使用NSClient++ plugin)
  3. 可以指定自己编写的Plugin通过网络收集数据来监控任何情况(温度、警告……)
  4. 可以通过配置Nagios远程执行插件远程执行脚本
  5. 远程监控支持SSH或SSL加通道方式进行监控
  6. 简单的plugin设计允许用户很容易的开发自己需要的检查服务,支持很多开发语言(shell scripts、C++、Perl、ruby、Python、PHP、C#等)
  7. 包含很多图形化数据Plugins(Nagiosgraph、Nagiosgrapher、PNP4Nagios等)
  8. 可并行服务检查
  9. 能够定义网络主机的层次,允许逐级检查,就是从父主机开始向下检查
  10. 当服务或主机出现问题时发出通告,可通过email, pager, sms 或任意用户自定义的plugin进行通知
  11. 能够自定义事件处理机制重新激活出问题的服务或主机
  12. 自动日志循环
  13. 支持冗余监控
  14. 包括Web界面可以查看当前网络状态,通知,问题历史,日志文件等

安装方式:

基础插件的安装:gcc glibc glibc-common gd gd-devel xinetd openssl-devel

检测插件是否安装:# rpm -q gcc glibc glibc-common gd gd-devel xinetd openssl-devel

如果已经安装,则会出现以下的信息。


gcc-4.8.5-11.el7.x86_64
glibc-2.17-157.el7_3.1.x86_64
glibc-common-2.17-157.el7_3.1.x86_64
gd-2.0.35-26.el7.x86_64
gd-devel-2.0.35-26.el7.x86_64
xinetd-2.3.15-13.el7.x86_64
openssl-devel-1.0.1e-60.el7_3.1.x86_64


没有安装的话,执行下面命令:

# yum install -y gcc glibc glibc-common gd gd-devel xinetd openssl-devel

(yum与rpm的区别,rpm是红帽公司开发的软件管理软件,方便我们对软件的安装、卸载、升级等,但是rpm软件包之间的依赖性问题是很繁琐的。yum是fedora与redhat中shell前端的软件管理工具,基于rpm管理的,能够从指定的服务器下载相关软件,并可以自动的一次性解决依赖包问题)。


创建nagios用户与用户组:


#useradd -s  /sbin/nologin nagios
#mkdir  /usr/local/nagios
#chown nagios.nagios /usr/local/nagios

查看目录权限:


drwxr-xr-x. 9 nagios nagios 87 Mar  6 11:49 /usr/local/nagios/



编译安装nagios:

下载nagios:

wget  https://sourceforge.net/projects/nagios/files/nagios-4.x/nagios-4.3.1/nagios-4.3.1.tar.gz/download
tar -zxf nagios-4.3.1
cd nagios-4.3.1
./configure  --prefix=/usr/local/nagios


(解压文件,进入目录,配置软件的安装目录)


# make all


此步骤执行完毕之后,你会发现会提示很多有关于make的命令,建议都执行一次,我是按照网上教程进行操作的,结果少了一步,浪费了不少时间。


# make install
# make install-init
# make install-commandmode
# make install-config
# make install-webconf
# chkconfig --add nagios
# chkconfig --level 35 nagios on
# chkconfig --list nagios


前5步都是编译的过程,到了第六步是对安装之后的检测。

第六步是将系统服务加入到软件管理器中,能够对该服务进行管理。


nagios         	0:off	1:off	2:on	3:on	4:on	5:on	6:off

检测软件是否被正确安装:

切换目录到/usr/local/nagios/,如果存在目录etc、bin、sbin、share、var,则证明已经正确安装,其中每个目录的用途如下所示:


etc

nagios 配置文件所在目录

bin

nagios 可执行程序所在的目录

sbin

nagios CGI文件所在目录,也就是外部命令所需文件所在的目录

share

nagios 外部网页所在的目录

var

nagios日志文件、lock等文件所在的目录


安装nagios插件:


安装apache与php:

这两个并不是nagios运行必须,但是nagios提供了web访问界面,在利用web访问nagios的状态下,安装一个apache服务是必须的,但是apache服务是需要php支持的。

安装apache:


# wget http://archive.apache.org/dist/httpd/httpd-2.2.23.tar.gz
# tar zxvf httpd-2.2.23.tar.gz
# cd httpd-2.2.23
# ./configure --prefix=/usr/local/apache2
# make && make install

在configure的时候,apache服务需要检测apr与apr-util的存在,因此需要你的机器上安装了apr与apr-util服务,去apache官网上去下载apr与apr-util,安装普通的编译与安装方式进行安装。

然后对apache进行编译:

configure --prefix=/usr/local/apache2 --with-apr-util=/usr/local/apr-util(这里指的是apr-util的安装路径,有可能还需要添加apr的路径)。

安装php:


# wget http://cn2.php.net/distributions/php-5.4.10.tar.gz
# tar zxvf php-5.4.10.tar.gz
# cd php-5.4.10
# ./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache2/bin/apxs
#make && make install

问题(1)就是第一次编译安装apache后,没有/usr/local/apache2目录,从而也就没有/usr/local/apache2/bin/apxs,所以再一次对apache进行编译之后出现了这个目录。


问题(2)有的博客上将make && make install写作make & make install。验证时候前者是正确的,因为后者是位与的关系,也就是说make与make install同时会运行,导致两次编译进而发生错误。

配置apache文件:

进入到/usr/local/apache2/conf.d,找到httpd.conf文件,修改以下内容:


User daemon 
Group daemon

修改为:


User nagios
Group nagios


修改访问页面:


<IfModule dir_module> 
  DirectoryIndex index.html 
</IfModule>

修改为:


<IfModule dir_module> 
  DirectoryIndex index.html index.php 
     AddType application/x-httpd-php .php 
</IfModule>

按照理论apache会自动访问系统目录/etc/httpd/conf.d/下面的配置文件,因此在上述过程中make install-webconf主要的作用是nagios下面sample-config/http.conf配置成apache的配置文件。

手工自己进行添加:


#cp sample-config/httpd.conf /usr/local/apache/conf/nagios.conf

这样之后在/usr/local/apache/conf/httpd.conf 文件添加 Include conf/nagios.conf 注意include第一个字母大写


不能写include nagios.conf 会无法识别。

然后打开nagios.conf文件:


#setting for nagios 
ScriptAlias /nagios/cgi-bin "/usr/local/nagios/sbin" 
<Directory "/usr/local/nagios/sbin"> 
     AuthType Basic 
     Options ExecCGI 
     AllowOverride None 
     Order allow,deny 
     Allow from all 
     AuthName "Nagios Access" 
     AuthUserFile /usr/local/nagios/etc/htpasswd.uers             //用于此目录访问身份验证的文件 
     Require valid-user 
</Directory> 
Alias /nagios "/usr/local/nagios/share" 
<Directory "/usr/local/nagios/share"> 
     AuthType Basic 
     Options None 
     AllowOverride None 
     Order allow,deny 
     Allow from all 
     AuthName "nagios Access" 
     AuthUserFile /usr/local/nagios/etc/htpasswd 
     Require valid-user 
</Directory>

创建apache验证文件:

在上面的用汉字标明的目录一行中,指定代了验证的文件。
创建验证文件:

# /usr/local/apache2/bin/htpasswd -c /usr/local/nagios/etc/htpasswd.users kp

这样就在/usr/local/nagios/etc 目录下创建了一个htpasswd 验证文件。

启动apache服务:

/usr/local/apache2/bin/apachectl start/stop/restart

启动nagios:

因为在上述过程中已经将nagios服务加入到软件管理系统中。

service nagios start/stop/restart

apache默认端口是80,ip是localhost。若出现socket问题,进入apache配置文件中对端口与ip进行修改。

在浏览器中输入:http://ip:port/nagios/   出现你访问的页面。

到这里nagios的搭建已经完成了。