nagios 详细的安装及配置!

简介:

一、安装前的准备

1.下载到核心源码:

wget http://sourceforge.net/projects/nagios/files/nagios-3.x/nagios-3.4.3/nagios-3.4.3.tar.gz/download 

2.下载插件包:

[root@gjp ~]# wget http://nchc.dl.sourceforge.net/project/nagiosplug/nagiosplug/1.4.16/nagios-plugins-1.4.16.tar.gz

3. nagios服务器端软件和客户端软件

[root@gjp ~]# wget http://nchc.dl.sourceforge.net/project/nagios/nrpe-2.x/nrpe-2.13/nrpe-2.13.tar.gz

4.源码安装前需要先确定 已经安装 apache,gcc,GD库和开发库


我本地DVD上没有gd-devel,所以我又加一一个163的镜像源 
yum install -y httpd php gcc glibc glibc-common gd gd-devel perl make

clip_image002


二、监控端:

1个步骤:


clip_image004

创建一个名为nagios的帐号并给定登录口令 
/usr/sbin/useradd nagios 
passwd nagios #密码123456 
创建一个用户组名为nagcmd用于从Web接口执行外部命令。将nagios用户和apache用户都加到这个组中。 
/usr/sbin/groupadd nagcmd 
/usr/sbin/usermod -G nagcmd nagios 
/usr/sbin/usermod -G nagcmd apache 
clip_image006

[root@gjp nagios]# yum install sendmail –y

clip_image008
cd /root nagios下载目录 
tar xzf nagios-3.4.3.tar.gz

cd nagios 
运行Nagios配置脚本并使用先前开设的用户及用户组: 
./configure --with-command-group=nagcmd

下面这个,我这里没指定

clip_image010

clip_image012

make all 
make install

clip_image014
make install-init

clip_image016

make install-config 
clip_image018

make install-commandmode

把Nagios加入到服务列表中以使之在系统启动时自动启动

clip_image020

现在还不能启动Nagios-还有一些要做的... 
客户后配置 
样例配置文件默认安装在这个目录下/usr/local/nagios/etc,这些样例文件可以配置Nagios使之正常运行,只需要做一个简单的修改... 
用你擅长的编辑器软件来编辑这个/usr/local/nagios/etc/objects/contacts.cfg配置文件,更改email地址nagiosadmin的联系人定义信息中的EMail信息为你的EMail信息以接收报警内容。 
vi /usr/local/nagios/etc/objects/contacts.cfg

配置WEB接口 
安装Nagios的WEB配置文件到Apache的conf.d目录下

nagios-3.4.3.tar.gz解压后的nagios中执行

[root@gjp ~]# cd nagios

[root@gjp nagios]# make install-webconf

在ls /etc/httpd/conf.d/下,会出现nagios.conf 文件 

2个步骤:ngios插件


clip_image022

下面使用的版本与上面不同: 
展开Nagios插件的源程序包 
cd /root 
tar xzf nagios-plugins-1.4.16.tar.gz 
cd nagios-plugins-1.4.16 
yum install -y openssl openssl-devel 
编译并安装插件 
./configure --with-nagios-user=nagios --with-nagios-group=nagios 
make && make install

3个步骤:安装nagios汉化插件(此步,我跳过了)

clip_image024

clip_image026

4个步骤:

clip_image028

clip_image030

我在这里采用的yum安装!

clip_image032

clip_image034

clip_image036

以上,是参考文档,我这里如下配置:

因为前面建立了个用户组,把nagios和apache都添加进去了!因此,我这里无需改动:除了这个无需改动clip_image038,其他修改如上

clip_image040

创建一个nagiosadmin的用户用于Nagios的WEB接口登录。记下你所设置的登录口令,一会儿你会用到它。 
htpasswd -c /usr/local/nagios/etc/htpasswd nagiosadmin #密码123456

clip_image042

重启Apache服务以使设置生效。 
service httpd restart

如果出现服务启动不了,出现这样

clip_image044

clip_image046

clip_image048

启动Nagios 
验证Nagios的样例配置文件 
/usr/local/nagios/bin/nagios -v /usr/local/nagios/etc/nagios.cfg 
如果没有报错,可以启动Nagios服务 
service nagios start 
[root@gjp nagios-plugins-1.4.16]# service nagios start

Starting nagios: done.

界面:

http://192.168.1.104:1080/nagios/

访问时,输入用户名和密码:则是vim /usr/local/nagios/etc/htpasswd 该文件中的用户和密码!

211524500.jpg

三、中间出现的问题及解决方法:


这时,监控端已配置好:

http://192.168.1.104:1080/nagios/

访问时,却发现,访问不到

clip_image052

clip_image054

clip_image056

Apache重启才能生效!

clip_image058

如果无法访问,查看apache服务是否开启,如果启动不了,查原因,我这里是由于selinux没关闭,导致的,vim /etc/selinux/config 把#SELINUX=enforcing

SELINUX=disabled

如果apache正常,扔无法打开web,则查看iptables

如iptables –F 规则,清理下,ok

四、NEPR监控远程主机


在监控机上安装

cd /root 
tar xvf nrpe-2.13.tar.gz 
cd nrpe-2.13 
./configure 
make all && make install-plugin 
在文件/usr/local/nagios/etc/objects/commands.cfg后面增加: 
# 'check_nrpe' command definition 
define command{ 
command_name check_nrpe 
command_line $USER1$/check_nrpe -H $HOSTADDRESS$ -t 30 -c $ARG1$ 
}

定义主机:

clip_image060

vim /usr/local/nagios/etc/nagios.cfg

clip_image062

/usr/local/nagios/bin/nagios -v /usr/local/nagios/etc/nagios.cfg

监测看到如下: 这里有1个警告,是没问题的!

clip_image064

/etc/init.d/nagios restart

看到界面如下:

clip_image066

定义相应的服务:

vim /usr/local/nagios/etc/objects/service.cfg (自己创建的)

[root@root objects]# cat service.cfg

define service{

use generic-service;

host_name test;

service_description users;

check_command check_nrpe!check_users;

}

define service{

use generic-service;

host_name test;

service_description load;

check_command check_nrpe!check_load;

}

define service{

use generic-service;

host_name test;

service_description disk;

check_command check_nrpe!check_disk;

}

define service{

use generic-service;

host_name test;

service_description zombie;

check_command check_nrpe!check_zombie_procs;

}

define servicegroup{

servicegroup_name servergroup;

alias server-group;

members test,users,test,load,test,disk,test,zombie;

}(这个文档对应的是被监控端的vim /usr/local/nagios/etc/nrpe.cfg 中定义的命令,如command[check_users]=/usr/local/nagios/libexec/check_users -w 10 -c 16)

写完后,进行验证:

/usr/local/nagios/bin/nagios -v /usr/local/nagios/etc/nagios.cfg

然后记着重启nagios

clip_image068

出现上面:

在被监控端192.168.1.106:

clip_image070

在监控端:

[root@root objects]# /usr/local/nagios/libexec/check_nrpe -H 192.168.1.106 -c check_disk

DISK OK - free space: / 6666 MB (72% inode=95%);| /=2521MB;9188;9488;0;9688

clip_image072

上面的HTTP错误,开放80端口,在httpd.conf中,增加Listen 80,然后,apache服务重启,解决!

clip_image074

clip_image076

clip_image080clip_image078

clip_image082

clip_image084

clip_image086

在被监控机上:

clip_image088

clip_image090

在这里,我的操作如下: 
groupadd nagios 
useradd -g nagios -d /usr/local/nagios -s /sbin/nologin nagios 
cd /tmp/ 
tar xvf nagios-plugins-1.4.16.tar.gz 
cd nagios-plugins-1.4.16 
./configure --with-nagios-user=nagios --with-nagios-group=nagios --enable-redhat-pthread-workaround 
make && make install 
clip_image092
cd /root 
tar xvfz nrpe-2.13.tar.gz 
cd nrpe-2.13 
./configure 
make all 
make install-plugin 
make install-daemon 
make install-daemon-config 
clip_image094
clip_image096

具体操作如下:

更改/usr/local/nagios/etc/nrpe.cfg文件,在参数allowed_hosts后添加监控机ip(多个ip以逗号分隔,目前监控及ip为222.189.237.136,112.84.184.111)

clip_image098

可以在/etc/services结尾增加: 
echo 'nrpe 5666/tcp # NRPE' >> /etc/services 
clip_image100
/usr/local/nagios/libexec/check_nrpe -H localhost 
NRPE v2.13

clip_image102

更改 /usr/local/nagios/etc/nrpe.cfg,把原来command都注释掉 
nrpe.cfg文件里包含需要监控远程主机的命令,如: 
echo ' 
command[check_users]=/usr/local/nagios/libexec/check_users -w 10 -c 16 
command[check_load]=/usr/local/nagios/libexec/check_load -w 15,10,5 -c 30,25,20 
command[check_disk]=/usr/local/nagios/libexec/check_disk -w 500 -c 200 -p / 
command[check_zombie_procs]=/usr/local/nagios/libexec/check_procs -w 5 -c 10 -s Z

command[check_cpu_procs]=/usr/local/nagios/libexec/check_procs -w 40 -c 80 -m CPU

command[check_total_procs]=/usr/local/nagios/libexec/check_procs -w 150 -c 200 ' >> /usr/local/nagios/etc/nrpe.cfg

7)手工启动 
手工启动方法 /usr/local/nagios/bin/nrpe -c /usr/local/nagios/etc/nrpe.cfg -d

8)添加开机启动

echo '/usr/local/nagios/bin/nrpe -c /usr/local/nagios/etc/nrpe.cfg -d' >> /etc/rc.local 
9)验证nrpe是否监听 
netstat -tanp | grep nrpe


上述部分参考截图来自:

知识使用:http://blog.csdn.net/nicaiwa/article/details/9185565


《高性能Linux服务器构建实战:运维监控、性能调优与集群应用%28完整%29.pdf》


本文转自 gjp0731 51CTO博客,原文链接:http://blog.51cto.com/guojiping/1293933


相关文章
|
2月前
|
监控 应用服务中间件
Nagios 服务器 Nrpe 配置
Nagios服务器需安装NRPE并定义监控命令于`command.cfg`中。示例配置如下:`check_nrpe -H $HOSTADDRESS$ -c $ARG1$`。客户端配置文件如`192.168.149.128.cfg`可引用NRPE配置的命令,如`check_nrpe!check_load`以监控负载。监控HTTP关键词使用`check_http`命令加参数,如`-I`指定IP,`-u`指定URL,`-s`指定关键词,可在`command.cfg`中定义如`check_http_word`命令,并在主机配置文件中引用。
61 13
|
Web App开发 开发工具 机器学习/深度学习
|
监控 网络协议 测试技术
|
Web App开发 开发工具 机器学习/深度学习
|
Web App开发 监控 网络架构
|
监控 关系型数据库 MySQL