脚本监控当前服务器负载情况

简介:

#!/bin/bash

#触发阈值发邮件还没有写.

export PATH

export LANG=zh_CN.UTF-8

#先配置好mailx邮箱账号密码:

#cat>/etc/mail.rc<<"EOF"

#set sendcharsets=iso-8859-1,utf-8

#set from=xxx@163.com

#set smtp=smtp.163.com

#set smtp-auth-user=xx@163.com

#set smtp-auth-password=xxx

#set smtp-auth=login

#EOF


readonly times=$(date +%Y"/"%m"/"%d" "%k":"%M)

readonly machine="192.168.1.10"


function top_check(){

   runup=$(top -n 1|grep user|awk -F '[, ]+' '{print $5}')

   echo "$times   $machine   运行多久: $runup 分钟"

 

   userd=$(top -n 1|grep user|awk -F '[, ]+' '{print $7}')

   echo "$times   $machine   当前在线用户数: $userd"

   

   load1=$(top -n 1|grep user|awk -F '[, ]+' '{print $11}')

   echo "$times   $machine   1分钟CPU负载: $load1"

   

   load5=$(top -n 1|grep user|awk -F '[, ]+' '{print $12}')

   echo "$times   $machine   5分钟CPU负载: $load5"

   

   load15=$(top -b -n 1|grep user|awk '{print $NF}')

   echo "$times   $machine   15分钟CPU负载: $load15"

   

   cpuus=$(top -n 1|grep Cpu|awk -F "," '{print $1}'|awk -F " " '{print $2}')

   echo "$times   $machine   用户空间占用CPU百分比: $cpuus"


   cpusy=$(top -n 1|grep Cpu|awk -F "," '{print $2}'|awk -F " " '{print $2}')

   echo "$times   $machine    内核空间占用CPU百分比: $cpusy"


   cpuni=$(top -n 1|grep Cpu|awk -F "," '{print $3}'|awk -F " " '{print $2}')

   echo "$times   $machine    改变过优先级的进程占用CPU的百分比: $cpuni"


   cpuid=$(top -n 1|grep Cpu|awk -F "," '{print $4}'|awk -F " " '{print $2}')

   echo "$times   $machine    空闲CPU百分比: $cpuid"


   cpuwa=$(top -n 1|grep Cpu|awk -F "," '{print $5}'|awk -F " " '{print $2}')

   echo "$times   $machine    I/O等待占用CPU的百分比: $cpuwa"


   cpuhi=$(top -n 1|grep Cpu|awk -F "," '{print $6}'|awk -F " " '{print $2}')

   echo "$times   $machine    硬中断占用CPU的百分比: $cpuhi"


   cpusi=$(top -n 1|grep Cpu|awk -F "," '{print $7}'|awk -F " " '{print $2}')

   echo "$times   $machine    软中断占用CPU的百分比: $cpusi"


   cpust=$(top -n 1|grep Cpu|awk -F "," '{print $8}'|awk -F " " '{print $2}')

   echo "$times   $machine    虚拟 CPU 等待实际 CPU 的时间的百分比: $cpust"

   

   #内存部分M为单位

   memtotal=$(($(top -n 1|grep buff/cache|awk -F '[, ]+' '{print $4}') / 1024))

   echo "$times   $machine   内存总共: $memtotal M"

   memfree=$(($(top -n 1|grep buff/cache|awk -F '[, ]+' '{print $7}') / 1024))

   echo "$times   $machine   空闲内存: $memfree M"

   memused=$(($(top -n 1|grep buff/cache|awk -F '[, ]+' '{print $10}') / 1024))

   echo "$times   $machine   已使用内存: $memused M"

   membuff=$(($(top -n 1|grep buff/cache|awk -F '[, ]+' '{print $13}') / 1024))

   echo "$times   $machine   内存buff/cache: $membuff M"

   #swap部分M

   swaptotal=$(($(top -n 1|grep avail|awk -F '[, ]+' '{print $3}') / 1024))

   echo "$times   $machine   swap总共: $swaptotal M"

   swapfree=$(($(top -n 1|grep avail|awk -F '[, ]+' '{print $6}') / 1024))

   echo "$times   $machine   swap空闲: $swaptotal M"

   swapused=$(($(top -n 1|grep avail|awk -F '[, ]+' '{print $9}') / 1024))

   echo "$times   $machine   swap已使用: $swapused M"

   swapavail=$(($(top -n 1|grep avail|awk -F '[, ]+' '{print $11}') / 1024))

   echo "$times   $machine   swap内存avail Mem: $swapavail M"

   

}

files="/tmp/top.logs"

top_check >$files

dos2unix -k $files

mailx -s "$machine" xxx@vip.qq.com < $files

本文转自  一招拜师  51CTO博客,原文链接:http://blog.51cto.com/sadoc/1942830

相关文章
|
2月前
|
运维 Java Linux
【运维基础知识】Linux服务器下手写启停Java程序脚本start.sh stop.sh及详细说明
### 启动Java程序脚本 `start.sh` 此脚本用于启动一个Java程序,设置JVM字符集为GBK,最大堆内存为3000M,并将程序的日志输出到`output.log`文件中,同时在后台运行。 ### 停止Java程序脚本 `stop.sh` 此脚本用于停止指定名称的服务(如`QuoteServer`),通过查找并终止该服务的Java进程,输出操作结果以确认是否成功。
53 1
|
3月前
|
存储 弹性计算 运维
自动化监控和响应ECS系统事件
阿里云提供的ECS系统事件用于记录云资源信息,如实例启停、到期通知等。为实现自动化运维,如故障处理与动态调度,可使用云助手插件`ecs-tool-event`。该插件定时获取并转化ECS事件为日志存储,便于监控与响应,无需额外开发,适用于大规模集群管理。详情及示例可见链接文档。
|
3月前
|
存储 监控 Linux
监控Linux服务器
详细介绍了如何监控Linux服务器,包括监控CPU、内存、磁盘存储和带宽的使用情况,以及使用各种系统监控工具如vmstat、iostat、sar、top和dstat来分析系统性能,并推荐了一些开源监控系统。
58 0
监控Linux服务器
|
4月前
|
运维 监控 数据库
自动化运维:使用Python脚本实现服务器监控
【8月更文挑战第31天】在这篇文章中,我们将探索如何利用Python编写简单的脚本来实现对服务器的基本监控。通过学习和应用这些技术,你可以快速检测服务器的状态,包括CPU使用率、内存占用和磁盘空间等关键指标。这不仅有助于及时发现问题,还能提升运维效率。文章将逐步引导你理解监控的重要性,并展示如何从零开始构建自己的监控工具。
|
4月前
|
监控 数据挖掘 Linux
Linux服务器PBS任务队列作业提交脚本的使用方法
【8月更文挑战第21天】在Linux服务器环境中,PBS任务队列能高效管理及调度计算任务。首先需理解基本概念:作业是在服务器上执行的任务;队列则是等待执行任务的列表,具有不同的资源限制与优先级;节点指分配给作业的计算资源。
616 4
|
4月前
|
负载均衡 网络协议 Linux
在Linux中,常用WEB服务器负载架构有哪些?
在Linux中,常用WEB服务器负载架构有哪些?
|
4月前
|
存储 运维 监控
自动化运维:使用Python脚本进行服务器监控
【8月更文挑战第31天】在数字化时代,服务器的稳定运行对于企业至关重要。本文将介绍如何使用Python编写一个简单的服务器监控脚本,帮助运维人员及时发现并解决潜在问题。我们将从基础的服务器资源监控开始,逐步深入到日志分析与报警机制的实现。通过实际代码示例和操作步骤,使读者能够快速掌握自动化监控的技能,提升工作效率。
|
4月前
|
Prometheus 监控 Cloud Native
Web服务器的日志分析与监控
【8月更文第28天】Web服务器日志提供了关于服务器活动的重要信息,包括访问记录、错误报告以及性能数据。有效地分析这些日志可以帮助我们了解用户行为、诊断问题、优化网站性能,并确保服务的高可用性。本文将介绍如何使用日志分析和实时监控工具来监测Web服务器的状态和性能指标,并提供具体的代码示例。
485 0
|
4月前
|
监控 Linux 测试技术
|
20天前
|
人工智能 弹性计算 编解码
阿里云GPU云服务器性能、应用场景及收费标准和活动价格参考
GPU云服务器作为阿里云提供的一种高性能计算服务,通过结合GPU与CPU的计算能力,为用户在人工智能、高性能计算等领域提供了强大的支持。其具备覆盖范围广、超强计算能力、网络性能出色等优势,且计费方式灵活多样,能够满足不同用户的需求。目前用户购买阿里云gpu云服务器gn5 规格族(P100-16G)、gn6i 规格族(T4-16G)、gn6v 规格族(V100-16G)有优惠,本文为大家详细介绍阿里云gpu云服务器的相关性能及收费标准与最新活动价格情况,以供参考和选择。