Python自动化运维监控——批量监听页面发邮件(自由配置ini文件+smtplib)

本文主要是介绍Python自动化运维监控——批量监听页面发邮件(自由配置ini文件+smtplib),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、程序样式

1.listen.ini配置文件
listen.ini
2.监控页面
listen
3.日志
log

二、核心点

  1. smtplib库:这里使用了smtp.qq.comsmtp.163.com两个发送邮件的地址,使用邮箱用户名与授权码来实现登录,端口都使用465,最后抛出异常,finally里面最好判断一下srv这个变量存不存在,有可能断网就会导致登录失败,从而srv变量没有,最后srv.quit()最后报错
try:# 不能直接使用smtplib.SMTP来实例化,第三方邮箱会认为它是不安全的而报错# 使用加密过的SMTP_SSL来实例化,它负责让服务器做出具体操作,它有两个参数# 第一个是服务器地址,但它是bytes格式,所以需要编码# 第二个参数是服务器的接受访问端口,SMTP_SSL协议默认端口是465   25srv = smtplib.SMTP_SSL(smtp_srv.encode(), 465)# 使用授权码登录邮箱srv.login(from_addr, from_pwd)# 使用sendmail方法来发送邮件,它有三个参数# 第一个是发送地址# 第二个是接受地址,是list格式,可以同时发送给多个邮箱# 第三个是发送内容,作为字符串发送for to_addr in to_addrs:srv.sendmail(from_addr, [to_addr], msg.as_string())# srv.sendmail(from_addr, [to_addr1], msg.as_string())logger.info(to_addr+'发送成功')except Exception as e:logger.error('发送失败  '+str(e))finally:#无论发送成功还是失败都要退出你的QQ邮箱 检测srv是否存在  不检测会程序报错if 'srv' in globals():srv.quit()

2.读取ini配置文件:实现已定义参数,配置发件人、邮件邮箱,选择邮箱地址smtp.qq.com/smtp.163.com、邮件标题、监控页面地址(批量)、邮件人邮箱(批量)等参数,这里获取linten.ini配置文件的绝对路径有个问题,需要使用 sys.agrv[0]获取真实路径,不然就可能获取的是打包的程序.exe的系统路径temp

    #获取当前目录路径proDir = os.path.dirname(os.path.realpath(sys.argv[0]))
import os
import configparser
import sys# 读取配置文件
def getConfig(filename, section, option):""":param filename 文件名称:param section: 服务:param option: 配置参数:return:返回配置信息"""# 获取当前目录路径proDir = os.path.dirname(os.path.realpath(sys.argv[0]))# print(proDir)# 拼接路径获取完整路径configPath = os.path.join(proDir, filename)# print(configPath)# 创建ConfigParser对象conf = configparser.ConfigParser()# 读取文件内容conf.read(configPath,'utf-8')config = conf.get(section, option)return config
 # 发件人from_name = getConfig('listen.ini','listen','from_name')# 发件邮箱from_addr = getConfig('listen.ini','listen','from_addr')# 发件邮箱授权码,注意不是QQ邮箱密码from_pwd = getConfig('listen.ini','listen','from_pwd')# 收件邮箱to_addrs = getConfig('listen.ini','listen','to_addrs')to_addrs = to_addrs.split(',')# 邮件标题my_title = getConfig('listen.ini','listen','my_title')

3.日志输入logger.error()、logger.info()、 logger.warning()、 logger.debug()

logger = logging.getLogger()logger.setLevel(logging.INFO) #设置将日志输出到文件中,并且定义文件内容now = datetime.datetime.now().strftime("%Y-%m-%d_%H-%M-%S")fileinfo = logging.FileHandler(f"listen_{now}.log")fileinfo.setLevel(logging.INFO) #设置将日志输出到控制台controlshow = logging.StreamHandler()controlshow.setLevel(logging.INFO)#设置日志的格式formatter = logging.Formatter("%(asctime)s - %(levelname)s: %(message)s")fileinfo.setFormatter(formatter)controlshow.setFormatter(formatter)logger.addHandler(fileinfo)logger.addHandler(controlshow)

4.requests监控页面这里我判断了status_code,如果不是200就会发邮件,并且写了几个异常情况,也同样会记录日志与发邮件,并且当邮件数量达到5封,就会延时30分钟后,在检测,如果依旧有问题,就再发五封。

    urls = getConfig('listen.ini','listen','urls')urls = urls.split(',')while True: for url in urls:try:response = requests.get(url,timeout=5)code = response.status_codebody = str(url) + ' 运行异常,状态码:' + str(code) + '  请检查服务运行情况'# 定义邮件数量5i = 0if code != 200:i += 1logger.error(body)send_mail(body)if i >= 5:# 延时30分钟time.sleep(1800) i = 0except exceptions.HTTPError as e:logger.error("发生HTTP错误,原因是:"+ str(e))send_mail("发生HTTP错误,原因是:"+ str(e))time.sleep(5)except exceptions.Timeout as e:logger.error("访问超时,原因是:"+ str(e))send_mail("访问超时,原因是:"+ str(e))time.sleep(5)except Exception as e:logger.error("未知错误,原因是:" + str(e))send_mail("未知错误,原因是:" + str(e))time.sleep(5)

三、完整代码

listen.py

import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr
import requests
import logging
import datetime
import time 
from requests import exceptions
from getConfig import getConfigdef send_mail(body):# 发件人from_name = getConfig('listen.ini','listen','from_name')# 发件邮箱from_addr = getConfig('listen.ini','listen','from_addr')# 发件邮箱授权码,注意不是QQ邮箱密码from_pwd = getConfig('listen.ini','listen','from_pwd')# 收件邮箱to_addrs = getConfig('listen.ini','listen','to_addrs')to_addrs = to_addrs.split(',')# 邮件标题my_title = getConfig('listen.ini','listen','my_title')# 邮件正文msg = MIMEText(body, 'plain', 'utf-8')msg['From'] = formataddr([from_name, from_addr])# 邮件的标题msg['Subject'] = my_title# SMTP服务器地址,QQ邮箱的SMTP地址是"smtp.qq.com"# smtp_srv = "smtp.qq.com"smtp_srv = getConfig('listen.ini','listen','smtp_srv')try:# 不能直接使用smtplib.SMTP来实例化,第三方邮箱会认为它是不安全的而报错# 使用加密过的SMTP_SSL来实例化,它负责让服务器做出具体操作,它有两个参数# 第一个是服务器地址,但它是bytes格式,所以需要编码# 第二个参数是服务器的接受访问端口,SMTP_SSL协议默认端口是465   25srv = smtplib.SMTP_SSL(smtp_srv.encode(), 465)# 使用授权码登录QQ邮箱srv.login(from_addr, from_pwd)# 使用sendmail方法来发送邮件,它有三个参数# 第一个是发送地址# 第二个是接受地址,是list格式,可以同时发送给多个邮箱# 第三个是发送内容,作为字符串发送for to_addr in to_addrs:srv.sendmail(from_addr, [to_addr], msg.as_string())# srv.sendmail(from_addr, [to_addr1], msg.as_string())logger.info(to_addr+'发送成功')except Exception as e:logger.error('发送失败  '+str(e))finally:#无论发送成功还是失败都要退出你的QQ邮箱 检测srv是否存在  不检测会程序报错if 'srv' in globals():srv.quit()if __name__ == '__main__':logger = logging.getLogger()logger.setLevel(logging.INFO) #设置将日志输出到文件中,并且定义文件内容now = datetime.datetime.now().strftime("%Y-%m-%d_%H-%M-%S")fileinfo = logging.FileHandler(f"listen_{now}.log")fileinfo.setLevel(logging.INFO) #设置将日志输出到控制台controlshow = logging.StreamHandler()controlshow.setLevel(logging.INFO)#设置日志的格式formatter = logging.Formatter("%(asctime)s - %(levelname)s: %(message)s")fileinfo.setFormatter(formatter)controlshow.setFormatter(formatter)logger.addHandler(fileinfo)logger.addHandler(controlshow)# os.system('pause')print(  " ...............正在监听V8移动端wechat...............")print(	" .....................阿弥陀佛.......................")print(	"                       _oo0oo_                      ")print(	"                      o8888888o                     ")print(	'                      88" . "88                     ')print(	"                      (| -_- |)                     ")print(	"                      0\\  =  /0                    ")print(	"                   ___/‘---’\\___                   ")print(	"                  .' \\|       |/ '.                ")print(	"                 / \\\\|||  :  |||// \\             ")  print(	"                / _||||| -卍-|||||_ \\              ")print(	"               |   | \\\\\\  -  /// |   |           ")  print(	"               | \\_|  ''\\---/''  |_/ |            ") print(	"               \\  .-\\__  '-'  ___/-. /            ") print(	"             ___'. .'  /--.--\\  '. .'___           ")print(	"         ."" ‘<  ‘.___\\_<|>_/___.’>’ "".           ")print(	"       | | :  ‘- \\‘.;‘\\ _ /’;.’/ - ’ : | |        ")print(	"         \\  \\ ‘_.   \\_ __\\ /__ _/   .-’ /  /    ")   print(	"    =====‘-.____‘.___ \\_____/___.-’___.-’=====     ")print(	"                       ‘=---=’                      ")print(	"                                                    ")print(	"..................佛祖保佑, 一直监听..................")urls = getConfig('listen.ini','listen','urls')urls = urls.split(',')while True: for url in urls:try:response = requests.get(url,timeout=5)code = response.status_codebody = str(url) + ' 运行异常,状态码:' + str(code) + '  请检查服务运行情况'# 定义邮件数量5i = 0if code != 200:i += 1logger.error(body)send_mail(body)if i >= 5:# 延时30分钟time.sleep(1800) i = 0except exceptions.HTTPError as e:logger.error("发生HTTP错误,原因是:"+ str(e))send_mail("发生HTTP错误,原因是:"+ str(e))time.sleep(5)except exceptions.Timeout as e:logger.error("访问超时,原因是:"+ str(e))send_mail("访问超时,原因是:"+ str(e))time.sleep(5)except Exception as e:logger.error("未知错误,原因是:" + str(e))send_mail("未知错误,原因是:" + str(e))time.sleep(5)

getConfig.py

import os
import configparser
import sys# 读取配置文件
def getConfig(filename, section, option):""":param filename 文件名称:param section: 服务:param option: 配置参数:return:返回配置信息"""# 获取当前目录路径proDir = os.path.dirname(os.path.realpath(sys.argv[0]))# print(proDir)# 拼接路径获取完整路径configPath = os.path.join(proDir, filename)# print(configPath)# 创建ConfigParser对象conf = configparser.ConfigParser()# 读取文件内容conf.read(configPath,'utf-8')config = conf.get(section, option)return config

listen.ini

[listen]
#发件人
from_name = XXX
#登录邮箱地址 smtp.qq.com   smtp.163.com
smtp_srv = smtp.163.com
#发件邮箱
from_addr = xxxxxxxxxx@163.com
#发件邮箱授权码,请在qq 163邮箱账户选项里面查询
from_pwd = xxxxxxxxxxxx
#收件邮箱
to_addrs = xxxxx@dingtalk.com
#邮件标题
my_title = XXXXXXX异常告警#监控地址
urls = http://ecard.swpu.edu.com,127.0.0.1:80,xxxxxxxxx

这篇关于Python自动化运维监控——批量监听页面发邮件(自由配置ini文件+smtplib)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python实现文件下载、Cookie以及重定向的方法代码

《Python实现文件下载、Cookie以及重定向的方法代码》本文主要介绍了如何使用Python的requests模块进行网络请求操作,涵盖了从文件下载、Cookie处理到重定向与历史请求等多个方面,... 目录前言一、下载网络文件(一)基本步骤(二)分段下载大文件(三)常见问题二、requests模块处理

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

Python判断for循环最后一次的6种方法

《Python判断for循环最后一次的6种方法》在Python中,通常我们不会直接判断for循环是否正在执行最后一次迭代,因为Python的for循环是基于可迭代对象的,它不知道也不关心迭代的内部状态... 目录1.使用enuhttp://www.chinasem.cnmerate()和len()来判断for

使用Python实现高效的端口扫描器

《使用Python实现高效的端口扫描器》在网络安全领域,端口扫描是一项基本而重要的技能,通过端口扫描,可以发现目标主机上开放的服务和端口,这对于安全评估、渗透测试等有着不可忽视的作用,本文将介绍如何使... 目录1. 端口扫描的基本原理2. 使用python实现端口扫描2.1 安装必要的库2.2 编写端口扫

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

使用Python合并 Excel单元格指定行列或单元格范围

《使用Python合并Excel单元格指定行列或单元格范围》合并Excel单元格是Excel数据处理和表格设计中的一项常用操作,本文将介绍如何通过Python合并Excel中的指定行列或单... 目录python Excel库安装Python合并Excel 中的指定行Python合并Excel 中的指定列P

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

Redis多种内存淘汰策略及配置技巧分享

《Redis多种内存淘汰策略及配置技巧分享》本文介绍了Redis内存满时的淘汰机制,包括内存淘汰机制的概念,Redis提供的8种淘汰策略(如noeviction、volatile-lru等)及其适用场... 目录前言一、什么是 Redis 的内存淘汰机制?二、Redis 内存淘汰策略1. pythonnoe