问题1:nagios配置文件说明?

答:

commands.cfg是监控命令的配置文件

与其相关配置说明/usr/local/nagios/etc/objects/commands.cfg

Contect代码  
  1. define command{  
  2. command_name #定义命令的简称  
  3. command_line #定义当服务进行时Nagios要执行的动作。在命令执行以前,所有合法的宏都要被他们的值代替。  
  4. }  

 

contacts.cfg是监控报警联系人的配置文件

与其相关配置说明/usr/local/nagios/etc/objects/contacts.cfg

Contect代码  
  1. #这段是用来定义一个联系人  
  2. define contact{    
  3. contact_name #这个指令用来定义一个联系人的简称。他会在定义contactgroup时被引用到。在相应的环境中,宏定义$CONTACTNAME$会包含这个值。  
  4. alias                  #这个指令是为了定义一个联系人的具体的描述。在相应的环境中,宏定义$CONTACTALIAS$会包含这个值。  
  5. host_notification_period        #这个指令是为了定义,能够通知Contact中定义的那个简称联系人,关于主机有问题或者恢复正常状态的时间段。你可以把他想象成能够通知Contact关于主机的在线时间。  
  6. service_notification_period  #这个指令是为了定义,能够通知Contact中定义的那个简称联系人,关于服务的问题或恢复正常的时间段。  
  7. host_notification_options      # 这个指令为了定义主机在什么状态下会给联系人发通知。各个参数的描述如下:d=当主机的状态处于down时,发送通知;f=当主机状态处于stop时发送 通知。r=当主机恢复up状态时发送通知。n=什么状态下都不发送通知(w-warning , u-unknown,c-critical,r- recovery;d-down,u-unreachable)。  
  8. service_notification_options # 这个指令为了定义服务在什么状态下会给联系人发通知。各个参数的描述如下:w=当服务处于警告状态时发送通知 u=当服务的状态处于unknown时,发 送通知;f=当服务状态处于启动和停止时发送通知。c=当服务处于Critical状态时发送通知。n=什么状态下都不发送通知。  
  9. host_notification_commands   #这个指令是为了定义一个通知联系人关于主机问题或恢复正常的联系手段的一个列表。多个手段之间用逗号隔开。  
  10. service_notification_commands #这个指令是为了定义一个通知联系人关于服务问题或恢复正常的联系手段的一个列表。多个手段之间用逗号隔开。  
  11. email                        # 这个指令是为了定义联系人的email地址。这个将取决于你是如何定义你的notification commands.它可以用来给联系人发送紧急邮 件。在相应的环境中。宏定义$CONTACTEMAIL$将会包含它的值。  
  12. }  

 

 联系人组

Contect代码  
  1. define contactgroup{ #这段是用来定义一个联系人组。  
  2. contactgroup_name #联系组名称,通常定义得较短  
  3. alias #联系组别名,通常定义得较长  
  4. members #联系组成员  
  5. }  

 

timeperiods.cfg是时间定义配置文件

与其相关配置说明/usr/local/nagios/etc/objects/timeperiods.cfg

Contect代码  
  1. define timeperiod{  
  2. timeperiod_name  #时间段名称,通常定义得较短  
  3. alias                #时间段别名,通常定义得较长  
  4. sunday           #星期日时间段  
  5. monday          #星期一时间段  
  6. tuesday          #星期二时间段  
  7. wednesday   #星期三时间段  
  8. thursday        #星期四时间段  
  9. friday              #星期五时间段  
  10. saturday        #星期六时间段  
  11. }  

 

localhosts.cfg是被监控主机配置和被监控服务配置的文件

与其相关配置说明/usr/local/nagios/etc/objects/localhost.cfg

Contect代码  
  1. #这段是用来定义一个被监控的主机  
  2. define host{  
  3. host_name localhost #用这个名字在host group和service里标识一个主机  
  4. alias localhost #用来定义主机的一个完整名字或描述  
  5. address 127.0.0.1 #用来定义主机的地址,在有DNS服务器的,也可以用域名  
  6.  #用来定义在检测返回结果不是OK时,nagios重检测命令的次数。设置这个值为1会导致nagios一次也不重试就报警  
  7. max_check_attempts 1  
  8. #用一个time period项的名字来定义在哪段时间内激活对这台主机的主动检测。time period是定义在别的文件里的配置项,我们可以在这里用名字来引用它  
  9. check_period name  
  10.  #这是一个联系组列表。我们用联系组的名字来引用她们。多个联系组间用“,”来分隔  
  11. contact_groups name  
  12.  #这一项用来定义当一个服务仍然down或unreachable时,我们间隔多久重发一次通知给联系组  
  13. notification_interval  
  14. #这一项用一个time period定义来标识什么时间段内给联系组送通知。这里我们用time period定义的名字来引用她  
  15. notification_period  
  16.   # 这一项用来决定发送通知的时机。选项有:d = 当有down状态时发送通知,u = 当有unreachable状态时发送通知, r = 当有服务 recoveries时发送通知,f = 当主机启动或停机时发送通知。如果你给一个n选项,那么永远不会发送通知  
  17. notification_options   
  18. }  

 

 主机组

Contect代码  
  1. #这段是用来定义一个被监控的主机组  
  2. define hostgroup{       
  3. hostgroup_name #主机组名称,通常定义得较短   
  4. alias #主机组别名,通常定义得较长  
  5. members #主机组成员  
  6. }  

 

服务

Contect代码  
  1.  #这段是用来定义一个被监控的服务  
  2. define service{                       
  3. host_name #主机名称  
  4. service_description #服务描述  
  5. check_command #执行命令  
  6. max_check_attempts #最大失败尝试次数,值为1时只报警不重新检测  
  7. #常规检测间隔时间,默认为60分钟(常规检测是指无论服务状态是否正常,检测次数达到“最大次数”时)  
  8. normal_check_interval   
  9. #失败尝试间隔时间,默认为60分钟(失败尝试是指服务状态不正常,检查次数达到“最大次数”时)  
  10. retry_check_interval    
  11. check_period #检测时间段  
  12. #当服务状态不正常时通知联系人的间隔时间,值为0时不通知联系人  
  13. notification_interval   
  14. notification_period #通知联系人时间段  
  15. #通知联系人选项,w警告,u未知,c危急,f启动和停止,n不发送通知  
  16. notification_options   
  17. contact_groups #联系人组  
  18. }  

 

服务组

Contect代码  
  1. #这段是用来定义一个被监控的服务组  
  2. define servicegroup{                   
  3. servicegroup_name #服务组名称,通常定义得较短          
  4. alias #服务组别名,通常定义得较长  
  5. members #服务组成员  
  6. }  

  

cgi.cfg这个文件是与WEB相关

与其相关配置说明/usr/local/nagios/etc/cgi.cfg#去除用户验证

Contect代码  
  1. #去除用户验证  
  2. use_authentication=0  
  3. #多个用户用逗号隔开  
  4. authorized_for_system_commands=nagiosadmin  

 

templates.cfg是模板配置文件,这里面定义了一些模板以方便用户使用

 

问题2:nagios配置步骤?

答:

1.需要设置的组件是联系人和联系人组:/usr/local/nagios/etc/objects/contacts.cfg

Contect代码  
  1. define contact{  
  2.  contact_name jdoe  
  3.  alias John Due  
  4.  service_notification_commands notify-by-email  
  5.  host_notification_commands host-notify-by-emailes  
  6.  email john.doe@xxx.com  
  7. }  
Contect代码  
  1. define contactgroup{  
  2.  contactgroup_name server-admins  
  3.  alias Server Administrators  
  4.  members jdoe,albundy  
  5. }  

 

2.进行监视的主机和定义服务:/usr/local/nagios/etc/objects/localhost.cfg

 

Contect代码  
  1. define host{  
  2.         host_name                       ubuntu_1_2  
  3.         alias                           Ubuntu test server  
  4.         address                         192.168.1.2  
  5.         check_command                   check-host-alive  
  6.         max_check_attempts              20  
  7.         notifications_enabled           1  
  8.         event_handler_enabled           0  
  9.         flap_detection_enabled          0  
  10.         process_perf_data               1  
  11.         retain_status_information       1  
  12.         retain_nonstatus_information    1  
  13.         notification_interval           60  
  14.         notification_period             24x7  
  15.         notification_options            d,u,r  
  16. }  
Contect代码  
  1. define service{  
  2.         use                             service-template  
  3.         host_name                       ubuntu_1_2  
  4.         service_description             PING  
  5.         check_period                    24x7  
  6.         contact_groups                  server-admins  
  7.         notification_options            c,r  
  8.         check_command                   check_ping!300.0,20%!1000.0,60%  
  9. }  

重启nagios服务,证实Web管理接口中ping服务的可见性。

 

问题3:如何写nagios插件?

 

答:

nagios为了管理插件,nagios每次在查询一个服务的状态时,产生一个子进程,并且它使用来自该命令的输入和退出代码来确定具体的状态。

 

退出状态代码含义

OK:退出代码是0,服务正常工作

WARNING:退出代码是1,服务处于警告状态

CRITICAL:退出代码是2,服务处于危险状态

UNKNOWN:退出代码是3,服务处于未知状态

 

简单实现:

工作脚本check_getloadavg.py

Python代码  
  1. #!/usr/bin/env python  
  2.   
  3. import os,sys  
  4. (d1, d2, d3) = os.getloadavg()  
  5.   
  6. if d1 >= 5.0:  
  7.     print "GETLOADAVG CRITICAL: Load average is %.2f" % (d1)  
  8.     sys.exit(2)  
  9. elif d1 >= 2.0:  
  10.     print "GETLOADAVG WARNING: Load average is %.2f" % (d1)  
  11.     sys.exit(1)  
  12. else:  
  13.     print "GETLOADAVG OK: Load average is %.2f" % (d1)  
  14.     sys.exit(0)  

 

 nagios注册该插件脚本/usr/local/nagios/etc/objects/commands.cfg

Contect代码  
  1. define command{  
  2.         command_name    check_mygetloadavg  
  3.     command_line    /path/to/check_getloadavg #脚本存放的路径  
  4. }  

 

接下来创建关于这个插件的服务...

 

通常最好的方式是创建一个可配置的插件脚本,另一个好的实践是捕获所有的异常,统一管理。

获取平均负载的完整插件check_getloadavg2.py

Python代码  
  1. #!/usr/bin/env python  
  2.   
  3. import os  
  4. import sys  
  5. import getopt  
  6.   
  7. def usage():  
  8.     print """Usage: check_getloadavg [-h|--help] [-m|--mode 1|2|3] \ 
  9.     [-w|--warning level] [-c|--critical level]" 
  10.  
  11. Mode: 1 - last minute ; 2 - last 5 minutes ; 3 - last 15 minutes" 
  12. Warning level defaults to 2.0 
  13. Critical level defaults to 5.0"""  
  14.     sys.exit(3)  
  15.   
  16. try:  
  17.     options, args = getopt.getopt(sys.argv[1:],  
  18.         "hm:w:c:",  
  19.         "--help --mode= --warning= --critical=",  
  20.         )  
  21. except getopt.GetoptError:  
  22.     usage()  
  23.     sys.exit(3)  
  24.   
  25. argMode = "1"  
  26. argWarning = 2.0  
  27. argCritical = 5.0  
  28.   
  29. for name, value in options:  
  30.     if name in ("-h""--help"):  
  31.         usage()  
  32.     if name in ("-m""--mode"):  
  33.         if value not in ("1""2""3"):  
  34.             usage()  
  35.         argMode = value  
  36.     if name in ("-w""--warning"):  
  37.         try:  
  38.             argWarning = 0.0 + value  
  39.         except Exception:  
  40.             print "Unable to convert to floating point value\n"  
  41.             usage()  
  42.     if name in ("-c""--critical"):  
  43.         try:  
  44.             argCritical = 0.0 + value  
  45.         except Exception:  
  46.             print "Unable to convert to floating point value\n"  
  47.             usage()  
  48.   
  49. try:  
  50.     (d1, d2, d3) = os.getloadavg()  
  51. except Exception:  
  52.     print "GETLOADAVG UNKNOWN: Error while getting load average"  
  53.     sys.exit(3)  
  54.   
  55. if argMode == "1":  
  56.     d = d1  
  57. elif argMode == "2":  
  58.     d = d2  
  59. elif argMode == "3":  
  60.     d = d3  
  61.   
  62. if d >= argCritical:  
  63.     print "GETLOADAVG CRITICAL: Load average is %.2f" % (d)  
  64.     sys.exit(2)  
  65. elif d >= argWarning:  
  66.     print "GETLOADAVG WARNING: Load average is %.2f" % (d)  
  67.     sys.exit(1)  
  68. else:  
  69.     print "GETLOADAVG OK: Load average is %.2f" % (d)  
  70.     sys.exit(0)  

 

nagios注册该插件脚本/usr/local/nagios/etc/objects/commands.cfg

Contect代码  
  1. define command{  
  2.         command_name    check_mygetloadavg2  
  3.     command_line    /path/to/check_getloadavg2 -m $ARG1$ -w $ARG2$ -c $ARG3$  
  4.     }  

 

接下来创建关于这个插件的服务(注意:使用感叹号!来分隔插件参数)

Contect代码  
  1. define service{  
  2.         use                             service-template  
  3.         host_name                       localhost  
  4.         service_description             LoadAverage2  
  5.         check_period                    24x7  
  6.         contact_groups                  server-admins  
  7.         notification_options            c,r  
  8.         check_command                   check_mygetloadavg2!1!3.0!6.0  
  9. }  

 

ps:

添加启动服务

rc-update add nagios default

打开/usr/local/nagios/share/config.inc.php,把:

$cfg['cgi_base_url']='/nagios/cgi-bin'

改为(实际情况修改):

$cfg['cgi_base_url']='/cgi-bin'

支持故障时的事件定义,可以先行解决一些问题。

可以很容易地定制开发自己需要的服务监测插件。

Nagios core 只是个Daemon,负责调度,真正的检测操作还是通过Nagios plugins来实现的。

cpu是否超载?

网络接口是否满负荷?

nagios将所有的信息简化为‘工作,可疑,故障’

这可以帮助操作员根据预定义的和可配置的标准,重点关注最重要的,最关注的问题。

nagios内置了报告停机时间的功能