monicazhang 发表于 2016-3-25 10:00:02

详解运维监控利器Nagios(3)-配置Nagios监控系统 (2)

来自:网络


详解运维监控利器Nagios 系列(三)-配置Nagios监控系统 (2)上接详解运维监控利器Nagios 系列(三)-配置Nagios监控系统 (1)1980172/1132415

(3)理解Nagios宏及其工作机制                      nagios安装 Nagios配置非常灵活,继承和引用是一大特征,另一个重要特征就是可以在命令行的定义里使用宏,通过定义宏,nagios可以灵活的获取主机、服务和其它对象的信息。 宏的工作机制 在执行命令之前,nagios将对命令里的每个宏替换成它们应当取得的值。这种宏替换发生在Nagios执行各种类型的宏时候。例如主机和服务的检测、通知、事件处理等。 宏的分类: 默认宏、按需而成的宏、用户自定制宏等。 默认宏: 主机IP地址宏 当在命令定义中使用主机或服务宏时,宏将要执行所用的值指向主机或服务所带有值。看下面这个例子,假定在check_ping命令定义里使用了一个主机对象,例如这样: define host{                    host_name                     ixdba                    address             192.168.12.246                    check_command                  check_ping                    ...                    } define command{                    command_name    check_ping                    command_line    /usr/local/nagios/libexec/check_ping -H $HOSTADDRESS$ -w 100.0,90% -c 200.0,60%                    } 那么执行这个主机检测命令时展开并最终执行的将是这样的:                      开源监控软件         /usr/local/nagios/libexec/check_ping -H 192.168.12.246 -w 100.0,90% -c 200.0,60% 命令参数宏 同样你可以向命令传递参数,这样可以保证命令定义更具通用性。参数指定在对象(象主机或服务)中定义,用一个“!”来分隔,例如这样: define service{                    host_name                linuxbox                    service_description PING                    check_command                   check_ping!200.0,80%!400.0,40%                    ...                    } 在上例中,服务的检测命令中含有两个参数(请参考$ARGn$宏),而$ARG1$宏将是"200.0,80%",同时$ARG2$将是"400.0,40%"(都不带引号)。假定使用之前的主机定义并这样来定义你的check_ping命令: define command{                    command_name    check_ping                    command_line    /usr/local/nagios/libexec/check_ping -H $HOSTADDRESS$ -w $ARG1$ -c $ARG2$                    } 那么对于服务的检测命令最终将是这样子的: /usr/local/nagios/libexec/check_ping -H 192.168.12.246 -w 200.0,80% -c 400.0,40% Nagios可用的全部的宏 主机宏 $HOSTNAME$主机简称(如"web"),取自于主机定义里的host_name域             nagios配置$HOSTADDRESS$主机地址。取自于主机定义里的address域 服务宏 $SERVICESTATE$ 服务状态描述,有w,u,c $SERVICEDESC$   对当前服务的描述联系人宏 $CONTACTNAME$   表示联系人,在联系人文件中定义 通知宏 $NOTIFICATIONTYPE$    返回下面信息:("PROBLEM", "RECOVERY", "ACKNOWLEDGEMENT", "FLAPPINGSTART", "FLAPPINGSTOP", "FLAPPINGDISABLED", "DOWNTIMESTART", "DOWNTIMEEND", or "DOWNTIMECANCELLED"). 日期/时间宏 $LONGDATETIME$当前的日期/时间戳 文件宏 $LOGFILE$日志文件的保存位置。 $MAINCONFIGFILE$主配置文件的保存位置。 其他宏 $ADMINEMAIL$全局的管理员EMail地址 $ARGn$指向第n个命令传递参数(通知、事件处理、服务检测等)。Nagios支持最多32个参数宏 (4)commands.cfg文件          此文件默认是存在的,无需修改即可使用,当然如果有新的命令需要加入时,在此文件进行添加即可。这里并未列出文件的所有内容,仅仅介绍了配置中用到的一些命令。 #下面是notify-host-by-email命令的定义 define command{       command_name    notify-host-by-email    #命令名称,即定义了一个主机异常时发送邮件的命令。       command_line    /usr/bin/printf "%b" "***** Nagios *****\n\nNotification Type: $NOTIFICATIONTYPE$\nHost: $HOSTNAME$\nState: $HOSTSTATE$\nAddress: $HOSTADDRESS$\nInfo: $HOSTOUTPUT$\n\nDate/Time: $LONGDATETIME$\n" | /bin/mail -s "** $NOTIFICATIONTYPE$ Host Alert: $HOSTNAME$ is $HOSTSTATE$ **" $CONTACTEMAIL$    #命令具体的执行方式,“-H $HOSTADDRESS$” 是定义目标主机的地址,这个地址在hosts.cfg文件中定义了。       } #下面是notify-host-by-email命令的定义 define command{       command_name    notify-service-by-email   #命令名称,即定义了一个服务异常时发送邮件的命令       command_line    /usr/bin/printf "%b" "***** Nagios *****\n\nNotification Type: $NOTIFICATIONTYPE$\n\nService: $SERVICEDESC$\nHost: $HOSTALIAS$\nAddress: $HOSTADDRESS$\nState: $SERVICESTATE$\n\nDate/Time: $LONGDATETIME$\n\nAdditional Info:\n\n$SERVICEOUTPUT$" | /bin/mail -s "** $NOTIFICATIONTYPE$ Service Alert: $HOSTALIAS$/$SERVICEDESC$ is $SERVICESTATE$ **" $CONTACTEMAIL$       } #下面是notify-host-by-email命令的定义          define command{       command_name    check-host-alive          #命令名称,用来检测主机状态。        command_line    $USER1$/check_ping -H $HOSTADDRESS$ -w 3000.0,80% -c 5000.0,100% -p 5   #这里的变量$USER1$在resource.cfg文件中进行定义,即$USER1$=/usr/local/nagios/libexec ,那么check_ping的完整路径为/usr/local/nagios/libexec/check_ping。 “-w 3000.0,80%”中“-w”说明后面的一对值对应的是“WARNING”状态,“80%”是其临界值。“-c 5000.0,100%”中“-c”说明后面的一对值对应的是“CRITICAL”,“100%”是其临界值。“-p 1”说明每次探测发送一个包。       }
#下面是notify-host-by-email命令的定义                        监控软件         define command{       command_name    check_ftp       command_line    $USER1$/check_ftp -H $HOSTADDRESS$ $ARG1$       #$ARG1$是指在调用这个命令的时候,命令后面的第一个参数。       } #下面是check_http命令的定义          define command{       command_name    check_http       command_line    $USER1$/check_http -I $HOSTADDRESS$ $ARG1$       } #下面是check_ssh命令的定义          define command{       command_name    check_ssh       command_line    $USER1$/check_ssh $ARG1$ $HOSTADDRESS$       } 。。。。。。
(5) hosts.cfg文件          此文件默认不存在,需要手动创建,hosts.cfg主要用来指定被监控的主机地址以及相关属性信息,一个配置好的实例如下:
define host{       use                     linux-server                #引用主机linux-server的属性信息,linux-server主机在templates.cfg文件中进行了定义。       host_name               web                           #主机名                   nagios实施      alias                  ixdba-web                   #主机别名       address               192.168.12.251                  #被监控的主机地址,这个地址可以是ip,也可以是域名。       }
         define host{       use                     linux-server       host_name            mysql       alias                  ixdba-mysql       address               192.168.12.237       }
         define hostgroup{                                                   #定义一个主机组               nagios培训         hostgroup_namesa-servers                   #主机组名称,可以随意指定。          alias         sa servers                              #主机组别名          members         web,mysql                         #主机组成员,其中“web”、“mysql”就是上面定义的两个主机。

想做Nagios, Zabbix,Cacti,iTop各种交流的,可以进入开源监控工具Nagios交流QQ群号 :476809427
页: [1]
查看完整版本: 详解运维监控利器Nagios(3)-配置Nagios监控系统 (2)