nagios被动检测

2024-03-10 23:40
文章标签 检测 被动 nagios

本文主要是介绍nagios被动检测,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

最近发现nagios主动检测有个不好的地方,就是权限的问题,不好控制,每次得有太多设置。而且对于类似想看下备份有没有成功之类的,用主动检测有很多不好的地方。这时候被动检测就派上用场了,

被动检测用来监控磁盘只读、是否备份成功等都是比较方便的。其实应该说被动检测是发挥自己编写插件的最好方式,所有监控的方式都使用被动检测,配置应该最方便了。

1: 先上一个被动检测的脚本,nagios这边叫做被动检测。其实在被监控的机器上应该叫做主动上报信息

#!/bin/sh
Host=192.168.0.2
Check_Desc="Check Disk Read Only"
OK=0
CRITICAL=2
houzhui=`date "+%Y%m%d"`
df -h|awk '{print $NF}'|grep '^/'|sort -u|while read line;doecho "nagios_test" > ${line}/nagios_test_${houzhui}if [ $? -ne 0 ];thenecho "${Host};${Check_Desc};${CRITICAL};CRITICAL. ${line} read only|result=-1"|send_nsca -H 192.168.0.1 -d ";" -c /etc/nagios/send_nsca.cfgexit 1firm ${line}/nagios_test_${houzhui}
done
if [ $? -eq 0 ];thenecho "${Host};${Check_Desc};${OK};OK. all disk is checked ok |result=0"|send_nsca -H 192.168.0.1 -d ";" -c /etc/nagios/send_nsca.cfg
fi
  • 这里假设nagios的ip是192.168.0.1。被监控的机器的ip是192.168.0.2。

  • 被动检测的话,被监控机器需要向nagios汇报的内容有:主机名称,监控项名称,四个返回值,显示在nagios网页的信息。

  • 主机名称:类似192.168.0.2,web_0_2。监控项名称:check_disk_read_only,check backup mysql。四个返回值:OK(0),WARNING(1),CRITICAL(2),UNKNOWN(3)。输出信息:自定义输入。

  • 使用send_nsca发送信息,send_nsca可以使用epel源安装nsca-client即可。yum install epel-release -y 。 yum install nsca-client -y。配置只需要改下/etc/nagios/send_nsca.conf的password

 

2: nagios监控端的nsca配置文件,需要配置服务器的ip和监听的端口(默认5667)。只需要配置一次

    server_port=5667

    server_address=192.168.0.1

    password=xxxx  ; 跟上面的password配置要对应上。不然信息无法接收。

    /etc/init.d/nsca restart启动nsca服务

3: nagios监控端的命令配置,只需要配置一次

    define command {

            command_name                    check_dummy

            command_line                    $USER1$/check_dummy $ARG1$

    }

4: nagios检测项目的配置

    define service{

            use passive-web-service

            host_name 192.168.0.2

            service_description Check Disk Read Only

            check_command check_dummy

    }

  • host_name和第一个说的${Host}要一致。service_description和第一个说的${Check_Desc}要一致。

  • check_dummy现在个人理解起来应该就是用来解析的,并且在网页上呈现。

5: nagios模板的配置文件如下

    define service{

            name                            passive-web-service

            active_checks_enabled           0

            passive_checks_enabled          1

            parallelize_check               1

            obsess_over_service             1

            check_freshness                 1     ;如果没接收到信息,则服务端主动刷新。

            freshness_threshold             120    ; 120s后就主动刷新了。

            notifications_enabled           1

            event_handler_enabled           1

            flap_detection_enabled          1

            process_perf_data               1

            retain_status_information       1

            retain_nonstatus_information    1

            is_volatile                     0

            check_period                    24x7

            max_check_attempts              3

            normal_check_interval           3

            retry_check_interval            2

            contact_groups                  web

            notification_options            w,u,c,r

            notification_interval           0

            notification_period             24x7

            register                        0

            }

  • 这个模板,一来不去主动探测,二来就是如果一定时间内接收不到信息,则主动刷新。

  • 120s主动刷新是在模板上配置的,对于监控的频率,我们可以自己设置。如果一天只汇报一次,就设置为86400。

 

基本上被动检测的配置就如上,被动检测个人感觉好处如下:

    1: nagios用户权限太小,不好去做的事,可以用被动检测。

    2: 在写备份脚本的时候,有时候突然想检测一下成功不,可以向nagios汇报下。不然实现方便就得成功发个邮件,不成功也发个邮件,太麻烦了。有些人会说成功可以不发邮件啊,但万一你备份的脚本被删除了,那你会一直认为是成功的,其实已经没在跑了。

    3: 另外,对于编写程序比较厉害的人,可以写个脚本,去检测一翻,如果成功则向上汇报All ok。如果有个不成功,可以在信息上echo出来,可以减少监控的选项。

 

最后附上本人的网络课堂地址,如有兴趣请点击: 实践哥

转载于:https://my.oschina.net/zhuangweihong/blog/603720

这篇关于nagios被动检测的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/795901

相关文章

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.