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

简介:

#!/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

相关文章
|
25天前
|
弹性计算 Shell Perl
ecs服务器shell常用脚本练习(二)
【4月更文挑战第1天】shell代码训练(二)
106 1
|
1月前
|
弹性计算 监控 数据可视化
ecs自定义监控
ecs自定义监控
24 1
|
1月前
|
Arthas 弹性计算 运维
阿里云ECS监控服务
阿里云ECS监控服务
403 2
|
1月前
|
弹性计算 运维 监控
ECS资源监控
ECS资源监控涉及CPU、内存、磁盘I/O、网络流量、系统负载和进程的关键指标,通过云服务商控制台、监控服务、API与SDK、运维工具进行实时监控和告警设置。支持历史数据查询、事件监控,以及使用Windows资源监视器和Linux系统工具进行操作系统层面监控。全面监控确保ECS实例稳定运行、资源有效利用和问题及时处理。如需特定云服务商的指导,请询问。
36 3
|
14天前
|
存储 弹性计算 Shell
ecs服务器shell常用脚本练习(十)
【4月更文挑战第11天】shell代码训练(十)
143 0
|
14天前
|
弹性计算 Shell Go
ecs服务器shell常用脚本练习(九)
【4月更文挑战第10天】shell代码训练(八)
140 0
|
18天前
|
弹性计算 Shell Linux
ecs服务器shell常用脚本练习(六)
【4月更文挑战第4天】shell代码训练(六)
110 0
|
23天前
|
弹性计算 Shell 应用服务中间件
ecs服务器shell常用脚本练习(四)
【4月更文挑战第4天】shell代码训练(四)
97 0
|
1月前
|
弹性计算 运维 监控
ecs监控与评估
阿里云ECS提供全面的监控与评估解决方案,包括云监控服务(实时资源指标、告警)、ECS实例详情页(运行状态查看)、资源负载评估(综合性能得分)、ECS Insight(多维度分析)、报警配置、流量管理优化(负载均衡、CDN)。这些工具帮助用户有效管理资源、识别潜在风险、优化性能,确保云服务稳定高效。
17 1
|
1月前
|
Ubuntu JavaScript 关系型数据库
在阿里云Ubuntu 20.04服务器中搭建一个 Ghost 博客
在阿里云Ubuntu 20.04服务器上部署Ghost博客的步骤包括创建新用户、安装Nginx、MySQL和Node.js 18.x。首先,通过`adduser`命令创建非root用户,然后安装Nginx和MySQL。接着,设置Node.js环境,下载Nodesource GPG密钥并安装Node.js 18.x。之后,使用`npm`安装Ghost-CLI,创建Ghost安装目录并进行安装。配置过程中需提供博客URL、数据库连接信息等。最后,测试访问前台首页和后台管理页面。确保DNS设置正确,并根据提示完成Ghost博客的配置。
在阿里云Ubuntu 20.04服务器中搭建一个 Ghost 博客