前言:
一直想写一个监控方面的脚本,然后想到了运维这方面的,后来就写了个脚本,下面话不多说了,来一起看看详细的介绍吧。
准备:
psutil模块(基本使用方法可以参考这篇文章:https://www.zzvips.com/article/75747.html)
正文:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
import os import time import re import smtplib from email.mime.text import MIMEText from email.header import Header import socket import psutil while True : def jianca(): print ( '[+]Write a port to a file' ) querys = os.popen( 'netstat -an' ).read() wsd = open ( 'netstat.txt' , 'w' ) wsd.write(querys) wsd.close() jianca() def swsd(): global usd,ow wsd = open ( 'netstat.txt' , 'r' ) swd = wsd.read() odf = re.findall( '(25[0-5]|2[0-4]\d|[0-1]\d{2}|[1-9]?\d)\.(25[0-5]|2[0-4]\d|[0-1]\d{2}|[1-9]?\d)\.(25[0-5]|2[0-4]\d|[0-1]\d{2}|[1-9]?\d)\.(25[0-5]|2[0-4]\d|[0-1]\d{2}|[1-9]?\d):(3389)' ,swd) usd = odf[ 0 ] print ( '[+]Query the IP address of a remote connection' ) df = usd[ 0 ],usd[ 1 ],usd[ 1 ],usd[ 3 ] wdst = "." .join(df) ow = wdst + ":" + usd[ 4 ] print (usd[ 0 ], '.' ,usd[ 1 ], '.' ,usd[ 2 ], '.' ,usd[ 3 ] + ":" ,usd[ 4 ]) swsd() def ipdw(): global wdf,ip,timsd s = socket.socket(socket.AF_INET,socket.SOCK_DGRAM) dw = s.connect(( '8.8.8.8' , 80 )) ip = s.getsockname()[ 0 ] print ( '[+]loacl IP:' ,ip) wdf = os.popen( 'tasklist' ).read() timsd = time.strftime( '%Y-%m-%d' ,time.localtime(time.time())) ipdw() def yunwei(): global cput,cp cput = psutil.cpu_times() cp = psutil.disk_io_counters() yunwei() def stm(): serder = "搜狐邮箱@sina.cn" revw = "收件箱@qq.com" zhengwen = '[+]Query the IP address of a remote connection' '{}\n' \ '[+]loacl IP:{}\n' \ '[+]A program running in the background:{}\n' \ '[+]The user / system / idle time of statistical CPU:{}\n' \ '[+]Disk I/O usage{}\n' \ '[+]Last send time:{}\n' . format (ow,ip,wdf,cput,cp,timsd) msg = MIMEText(zhengwen) msg[ 'From' ] = Header( '你的搜狐邮箱@sina.cn' ) msg[ 'TO' ] = Header( '收件箱@qq.com' , 'utf-8' ) sub = "实时监控" msg[ 'subject' ] = Header(sub, 'utf-8' ) try : smtp = smtplib.SMTP() smtp.connect( 'smtp.sina.cn' , 25 ) smtp.login( '搜狐邮箱@sina.cn' , '登录密码' ) smtp.sendmail(serder,revw,msg.as_string()) print ( '[+]发送出' ) except Exception as g: print ( '[-]发送失败,原因:' ,g) stm() time.sleep( 3600 ) |
实现原理:首先获取端口状态,然后写人一个txt用正则提取出想要的IP和端口。
然后获取正在后台运行的程序。在获取CPU和磁盘I/O的内存,然后通过邮箱发送‘
到指定收件箱。
运行截图:
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:http://www.cnblogs.com/haq5201314/p/8642123.html