nagios 监控脚本

2024-06-14 09:58
文章标签 脚本 监控 nagios

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

脚本数量(

[root@localhost etc]# ll /shell/nagios/
total 28
-rwxr-xr-x 1 root   root   372 Oct 31 10:25 check_cpu
-rwxr-xr-x 1 root   root   694 Oct 31 11:42 check_disk1
-rwxr-xr-x 1 nagios nagios 366 Nov  1 14:10 check_disk1_siz
-rwxr-xr-x 1 root   root   228 Nov  1 11:11 check_file_num
-rwxr-xr-x 1 root   root   501 Oct 30 11:34 check_mem
-rwxr-xr-x 1 root   root   420 Oct 30 11:34 check_net
-rwxr-xr-x 1 root   root   358 Oct 30 11:36 check_pro

1、[root@localhost nagios]# cat check_cpu 
#!/bin/bash
#
CPU_USE=`top -b1 n2|grep "Cpu"|awk NR==2|awk -F"," '{print $1}'|awk '{print $2}'|awk -F"us" '{print $1}'`
CPU_COM=`top -b1 n2|grep "Cpu"|awk NR==2|awk -F"," '{print $1}'|awk '{print $2}'|awk -F"%" '{print $1}'`
CPU_WAR=`expr $CPU_COM \> 80.0`
if [ $CPU_WAR -ne 1 ];then
echo "CPU OK.used:$CPU_USE"
exit 0
else
echo "CPU WARNING.used:$CPU_USE"
exit 1
fi


2、[root@localhost nagios]# cat check_mem 
#!/bin/bash
#
mem_tatol=`free -m|awk NR==2 |awk '{print $2}'`
mem_use=`free -m|awk NR==2 |awk '{print $3}'`
mem_free=`free -m|awk NR==2 |awk '{print $4}'`
if [ $mem_use -lt 1900 ];then
echo "MEM OK: tatol:$mem_tatol"M",used:$mem_use"M",free:$mem_free"M""
exit 0
#elif [ $mem_use -gt 3500 ]&&[ $mem_use lt 3800 ];then
# echo "MEM WARNING: tatol:$mem_tatol"M",used:$mem_use"M",free:$mem_free"M""."
# exit 1
else
echo "MEM CRITICAL: tatol:$mem_tatol"M",used:$mem_use"M",free:$mem_free"M"."
exit 2
fi

3、[root@localhost nagios]# cat check_disk1
#!/bin/bash
#
DIS_PAT="$1"
#CHE_COM=`/usr/local/nagios/libexec/check_disk -w 10 -c 5% -p $DIS_PAT`
DIS_FRE=`/usr/local/nagios/libexec/check_disk -w 10 -c 5% -p $DIS_PAT|awk -F":" '{print $2}'|awk '{print $2}'`
DIS_USE=`/usr/local/nagios/libexec/check_disk -w 10 -c 5% -p $DIS_PAT|awk -F"=" '{print $3}'|awk -F"MB" '{print $1}'`
DIS_TAT=`expr $DIS_FRE + $DIS_USE`
DIS_WAR=`echo "scale=0;$DIS_TAT * 0.9 "|bc|awk -F"." '{print $1}'`
#USE_COM=`expr  $DIS_USE \> $DIS_WAR`
if [ $DIS_USE -lt $DIS_WAR ];then
echo "DISK:$DIS_PAT OK. tatol:$DIS_TAT MB,used:$DIS_USE MB,free:$DIS_FRE MB"
exit 0
else
echo ""echo "DISK:$DIS_PAT WARNING. tatol:$DIS_TAT MB,used:$DIS_USE MB,free:$DIS_FRE MB"
exit 1
fi
[root@localhost nagios]# cat check_disk1_siz 
#!/bin/bash
#
###取磁盘数量
a=0
for b in {a..z}
do
df -hT |grep sd$b >> /dev/null
if [ $? -eq 0 ];then
let a++
echo "sd$b $DIS_SIZ" >> /var/log/size.txt
else
break 
fi
done
echo "硬盘块数:$a"
###定义配置文件格式
for pat in `df -hT|sed '1d'|awk '{print $7}'|grep -v "media"|grep -v "Mounted"`
do
/usr/local/nagios/libexec/check_disk1 $pat


done
[root@localhost nagios]# 

4、[root@localhost nagios]# cat check_net 
#!/bin/bash
#
NET_NUM="$1"
REC_TRAFFIC=`sar -n DEV 1 1 |grep $NET_NUM |awk '{print $5}'|awk NR==2`
SEN_TRAFFIC=`sar -n DEV 1 1 |grep $NET_NUM |awk '{print $6}'|awk NR==2`
COMPARE=`expr $REC_TRAFFIC \> 8000`
if [ $COMPARE -eq 0 ];then
echo "$NET_NUM OK.接收流量:$REC_TRAFFIC KB,发送流量:$SEN_TRAFFIC KB"
exit 0
else
echo "$NET_NUM WARNING.接收流量:$REC_TRAFFIC KB,发送流量:$SEN_TRAFFIC KB."
exit 1
fi


5、[root@localhost libexec]# cat check_pro
#!/bin/bash
#
PRO_NAME=$1
ps -elf |grep $PRO_NAME |grep -v "check_pro $PRO_NAME"|grep -v "grep $PRO_NAME" >> /dev/null
LIVE=`echo $?`
if [ $LIVE -eq 0 ];then
echo "$PRO_NAME OK. $PRO_NAME:running"
exit 0
else 
echo "$PRO_NAME Critical. $PRO_NAME:stoped"
fi


6、[root@localhost libexec]# cat check_file_num 
#!/bin/bash
#
FILE_DIR=$1
FILE_NUM=`ls -l $FILE_DIR|grep -v "^d"|wc -l`
FILE_NUM_1=`expr $FILE_NUM - 1`
if [ $FILE_NUM_1 -gt 100 ];then
echo "$FILE_DIR 目录中文件个数OK:$FILE_NUM_1 个"
exit 0
else
echo "$FILE_DIR 目录中文件个数WARNING:$FILE_NUM_1 个"
exit 1
fi

这篇关于nagios 监控脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

Spring Boot Actuator应用监控与管理的详细步骤

《SpringBootActuator应用监控与管理的详细步骤》SpringBootActuator是SpringBoot的监控工具,提供健康检查、性能指标、日志管理等核心功能,支持自定义和扩展端... 目录一、 Spring Boot Actuator 概述二、 集成 Spring Boot Actuat

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

如何在Ubuntu 24.04上部署Zabbix 7.0对服务器进行监控

《如何在Ubuntu24.04上部署Zabbix7.0对服务器进行监控》在Ubuntu24.04上部署Zabbix7.0监控阿里云ECS服务器,需配置MariaDB数据库、开放10050/1005... 目录软硬件信息部署步骤步骤 1:安装并配置mariadb步骤 2:安装Zabbix 7.0 Server