简单监控liunx中cpu、内存、磁盘及发送邮件参考

shell脚本

vim jk.sh  #命名脚本名

#!/bin/bash

time=`date "+%Y-%m-%d %H:%M:%S"`      #定义时间

echo "$time"

echo  "     警告!!!!!!"

cpu_info(){

cpu_free=`top -i -c -bn 1| grep Cpu | awk -F ":" ‘{print $2}‘ | awk -F "," ‘{print $4}‘ | awk -F " " ‘{print $1}‘| awk -F "." ‘{print $1}‘`  #取cpu空闲值

echo "cpu剩余量:" $cpu_free"%"

}

mem_info(){

mem_used=` free -h | grep Mem | awk -F ":" ‘{print $2}‘ | awk -F " " ‘{print $6}‘`   #取可用内存值

echo "---mem:"

echo "可用内存为:"$mem_used

}

disk_info(){

disk_total=`df -h | grep cent | awk -F " " ‘{print $2}‘`          #取磁盘总量

disk_used=`df -h | grep cent | awk -F " " ‘{print $3}‘`         #取磁盘使用量

disk_per=`df -h | grep cent | awk -F " " ‘{print $5}‘`        #取磁盘使用量率

echo "---disk:"

echo "磁盘总量:"$disk_total

echo "磁盘使用量:"$disk_used

echo "磁盘使用率:"$disk_per

}

mem=` free -h | grep Mem | awk -F ":" ‘{print $2}‘ | awk -F " " ‘{print $6}‘|sed s/M//g`  #把使用内存中的去M掉便于比较

disk=`df -h | grep cent | awk -F " " ‘{print $5}‘|sed s/%//g`   #把硬盘使用率中的百分号去掉便于比较

war_cpu=10   #定义cpu阈值值

war_mem=100 #定义可用内存阈值100M

war_disk=90   #定义磁盘使用率阈值

main(){

if [ $cpu -lt $war_cpu  ] || [ $mem -lt $war_mem ] ||[ $disk -gt $war_disk ]

#cpu剩余空间小于10   可用内存小于100M  磁盘使用率大于90

then

echo "---cpu:"

cpu_info

mem_info

disk_info

echo ".........等待处理........."

else

echo "-------------"

echo "Server‘s fine"

echo "-------------"

fi

}

main

用python实现发邮件

#导入模块

import paramiko

import smtplib

from email.mime.text import MIMEText

from email.header import Header

ssh = paramiko.SSHClient()

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

def send_mail(message):

sender = ‘aa[email protected]‘

receiver = [‘[email protected]‘]

subject = ‘报警‘

username = ‘aa[email protected]‘

password = ‘123456‘

msg = MIMEText(message, ‘plain‘, ‘utf-8‘)

msg[‘Subject‘] = Header(subject, ‘utf-8‘)

msg[‘From‘] = ‘warning<aa[email protected]>‘

msg[‘To‘] = "[email protected]"

smtp = smtplib.SMTP()

smtp.connect(‘smtp.163.com‘)

smtp.login(username, password)

smtp.sendmail(sender, receiver, msg.as_string())

smtp.quit()

def server():

ssh.connect("192.168.88.31", 22, ‘root‘, ‘123‘, timeout=3)  #连接192.168.88.31 端口22 用户root 密码123

stdin, stdout, stderr = ssh.exec_command(‘./jk.sh ‘ )   #在linux中执行./jk.sh

msg = stdout.read().decode(‘utf_8‘)

war = "警告"

while True:

if war in msg:

send_mail(msg)

print(‘发送成功!!!‘)

break

else:

print("server‘s find.")

break

server()

原文地址:https://www.cnblogs.com/heiguu/p/10011369.html

时间: 2024-11-20 09:38:07

简单监控liunx中cpu、内存、磁盘及发送邮件参考的相关文章

java获取cpu,内存,磁盘等信息

原文:java获取cpu,内存,磁盘等信息 源代码下载地址:http://www.zuidaima.com/share/1550463331306496.htm package com.zuidaima.util; import java.io.File; import java.io.InputStreamReader; import java.io.LineNumberReader; import java.util.ArrayList; import java.util.List; imp

linux系统CPU,内存,磁盘,网络流量监控脚本

前序 1,#cat /proc/stat/ 信息包含了所有CPU活动的信息,该文件中的所有值都是从系统启动开始累积到当前时刻 2,#vmstat –s 或者#vmstat 虚拟内存统计 3, #cat /proc/loadavg 从系统启动开始到当前累积时刻 4, #uptime 系统运行多长时间 5, #mpstat CPU的一些统计信息 6, # 一,linux系统CPU,内存,磁盘,网络流量监控脚本 [作者:佚名来源:不详时间:2010-7-6 [我来说两句大中小] cme.sh网络流量监

linux系统CPU内存磁盘监控发送邮件脚本之二

#!/bin/bash export PATH export LANG=zh_CN.UTF-8 # # #top之后输入数字1,可以查看每颗CPU的情况. # # #先配置好mailx邮箱账号密码: #cat>/etc/mail.rc<<"EOF" #set sendcharsets=iso-8859-1,utf-8 #set [email protected] #set smtp=smtp.163.com #set [email protected] #set sm

监控cpu内存磁盘,并实现邮件报警

1 #!/bin/bash 2 #获取当前时间 3 now=`date -u -d"+8 hour" +'%Y-%m-%d %H:%M:%S'` 4 #cpu使用阈值 5 cpu_warn='5' 6 #mem空闲阈值 7 mem_warn='1' 8 #disk使用阈值 9 disk_warn='5' 10 #获取主机IP,下条命令也可以获取 11 hostip=$(ip addr | awk '/^[0-9]+: / {}; /inet.*global/ {print gensub

CPU,内存,磁盘,指令以及它们之间的关系

众所周知计算机的组成是由控制器.运算器.存储器.输入.输出设备五部分构成,而其中CPU就是由控制器.运算器.寄存器和时钟四部分构成,磁盘和内存就属于存储设备. CPU指令主要有以下四个: 1.加载:把一个字节或一个字从内存中赋值到寄存器,覆盖原来寄存器的内容 2.存储:把一个字节或一个字从寄存器复制到内存中的某个位置,覆盖原来内存上这个位置的内容 3.操作:将两个寄存器的内容赋值到ALU,ALU对这两个字进行算术操作,将结果存储在某个寄存器中,以覆盖寄存器中原来的值 4.跳转:从指令本身抽取一个

Shell采集系统cpu 内存 磁盘 网络信息

cpu信息采集 cpu使用率 采集算法 通过/proc/stat文件采集并计算CPU总使用率或者单个核使用率.以cpu0为例,算法如下: 1. cat /proc/stat | grep ‘cpu0’得到cpu0的信息 2. cpuTotal1=user+nice+system+idle+iowait+irq+softirq 3. cpuUsed1=user+nice+system+irq+softirq 4. sleep 30秒 5. 再次cat /proc/stat | grep 'cpu0

性能优化之基础资源cpu&amp;内存(JVM)

本章主要介绍计算机的一些基础资源以及操作系统处理后的一些基础资源. 主要包括 cpu 内存 磁盘 网络 线程 本章会介绍这些资源的一些原理,介绍如何查看资源的数量,使用情况,对性能和整体计算机执行的一些影响.本章很多内容都基于linux,不是特殊说明,就是针对linux的情况.可能在其它操作系统不一定适用. 另外还会对jvm之上的一些内容做特殊说明,因为大家很大的一些积累都在jvm之上,内部的系统基本也建立在jvm上. jvm 指令 jvm 内存使用 cpu cpu是计算机里最重要的资源,没有之

【好书摘要】性能优化中CPU、内存、磁盘IO、网络性能的依赖

系统优化是一项复杂.繁琐.长期的工作,优化前需要监测.采集.测试.评估,优化后也需要测试.采集.评估.监测,而且是一个长期和持续的过程,不 是说现在优化了,测试了,以后就可以一劳永逸了,也不是说书本上的优化就适合眼下正在运行的系统,不同的系统.不同的硬件.不同的应用优化的重点也不同. 优化的方法也不同.优化的参数也不同.性能监测是系统优化过程中重要的一环,如果没有监测.不清楚性能瓶颈在哪里,怎么优化呢?所以找到性能 瓶颈是性能监测的目的,也是系统优化的关键.系统由若干子系统构成,通常修改一个子系

利用shell监控cpu、磁盘、内存使用率

利用shell监控cpu.磁盘.内存使用率,达到警报阈值发邮件进行通知 并配合任务计划,即可及时获取报警信息 #!/bin/bash ############################################## #Author: Liuzhengwei - [email protected] #QQ:1135960569 #Last modified: 2017-04-19 21:50 #Filename: jiankong.sh #Description:  #########