Nagios 插件可以由自己编写,就不用在网上找了,具体工作过程如下:

Nagios 的最激动人心的方面是可以轻松地编写您自己的插件,只需要了解一些简单的指导原则即可。为了管理插件,Nagios 每次在查询一个服务的状态时,产生一个子进程,并且它使用来自该命令的输出和退出代码来确定具体的状态。退出状态代码的含义如下所示:

OK —退出代码 0—表示服务正常地工作。

WARNING —退出代码 1—表示服务处于警告状态。

CRITICAL —退出代码 2—表示服务处于危险状态。

UNKNOWN —退出代码 3—表示服务处于未知状态。

最后一种状态通常表示该插件无法确定服务的状态。例如,可能出现了内部错误。

下面提供了一个 Python 示例脚本,用于检查 UNIX® 平均负载。它假定 2.0 以上的级别表示警告状态,而 5.0 以上的级别表示危险状态。这些值都采用了硬编码的方式,并且始终使用最近一分钟的平均负载。

清单 5. Python 插件—示例工作插件



  1. #!/usr/bin/env python  



  2. import os,sys  



  3. (d1, d2, d3) = os.getloadavg()  



  4. if d1 >= 5.0:  



  5. print "GETLOADAVG CRITICAL: Load average is %.2f" % (d1)  



  6. sys.exit(2)  



  7. elif d1 >= 2.0:  



  8. print "GETLOADAVG WARNING: Load average is %.2f" % (d1)  



  9. sys.exit(1)  



  10. else:  



  11. print "GETLOADAVG OK: Load average is %.2f" % (d1)  



  12. sys.exit(0)  





在编写了这个小的可执行插件之后,接下来是使用 Nagios 注册该插件,并创建一个检查平均负载的服务定义。

这项工作也是非常简单的:使用下面的内容创建一个名为 /etc/nagios-plugins/config/mygetloadavg.cfg 的文件,根据下面的示例,向 services.cfg 文件添加一个服务。请记住,必须在 hosts.cfg 配置文件中定义 localhost。

清单 6. 示例插件—使用 Nagios 进行注册



  1. define command{  



  2. command_name check_mygetloadavg  



  3. command_line /path/to/check_getloadavg  



  4. }  





清单 7. 创建一个使用示例插件的服务



  1. define service{  



  2. use service-template  



  3. host_name localhost  



  4. service_description LoadAverage  



  5. check_period 24x7  



  6. contact_groups server-admins  



  7. notification_options c,r  



  8. check_command check_mygetloadavg  



  9. }  





通过阅读文章,你只要按上面步骤一步一步来,就能为自己的 Nagios 做几个有用插件!