nagios:一个监视系统的框架。它用来集成各种监听服务的插件来实现对从属机的监听。
原理:
nagios通过周期性的自动调用插件去检查从属机器的状态,在此同时会创建一个队列,将返回的消息状态放入到队列中,然后通过web界面显示出来。
主要功能:
- 网络服务监控(SMTP、POP3、HTTP、NNTP、ICMP、SNMP、FTP、SSH)
- 主机资源监控(CPU load、disk usage、system logs),也包括Windows主机(使用NSClient++ plugin)
- 可以指定自己编写的Plugin通过网络收集数据来监控任何情况(温度、警告……)
- 可以通过配置Nagios远程执行插件远程执行脚本
- 远程监控支持SSH或SSL加通道方式进行监控
- 简单的plugin设计允许用户很容易的开发自己需要的检查服务,支持很多开发语言(shell scripts、C++、Perl、ruby、Python、PHP、C#等)
- 包含很多图形化数据Plugins(Nagiosgraph、Nagiosgrapher、PNP4Nagios等)
- 可并行服务检查
- 能够定义网络主机的层次,允许逐级检查,就是从父主机开始向下检查
- 当服务或主机出现问题时发出通告,可通过email, pager, sms 或任意用户自定义的plugin进行通知
- 能够自定义事件处理机制重新激活出问题的服务或主机
- 自动日志循环
- 支持冗余监控
- 包括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的搭建已经完成了。