p { margin-bottom: 0.25cm; line-height: 120% }
a:link { }
p { margin-bottom: 0.25cm; line-height: 120% }
a:link { }

一文件比较:

在实际维护过程中,涉及到许多文件对比的操作。在Linux下,自带diff命令,比较两个文件的结果如下。

其中a,d,c分别表示添加,删除,及修改操作。1,2c1,2中的1,2代表的是行号。从diff这个命令来看,其实不太直观。

p { margin-bottom: 0.25cm; line-height: 120% }
a:link { }

import
difflib

if
__name__=="__main__":

text1="""text1:

This
module provides classes and functions for comparing sequences.

including
HTML and context and unified diffs

difflib
document v7.4"""

text1_lines=text1.splitlines()

text2="""test2:

This
module provides classes and functions for Comparing sequences.

including
HTML and context and unified diffs

difflib
document v7.5"""

text2_lines=text2.splitlines()

d=difflib.Differ()

diff=d.compare(text1_lines,text2_lines)

print
'\n'.join(list(diff))

运行结果:

-
text1:

+
test2:

-
This module provides classes and functions for comparing sequences.

?
^

+
This module provides classes and functions for Comparing sequences.

?
^

including
HTML and context and unified diffs

-
difflib document v7.4

?
^

+
difflib document v7.5

?
^

其中-代表包含在第一个序列行中,但不包含在第二个序列行。

+包含在第二个序列行中,但不包含在第一个序列行

‘’两个序列行
一致

‘?’两个序列行存在增量差异

‘^’两个序列行存在的差异字符。

difflib的对比结果比diff中的更直观一些。我们还可以将结果更加美化一下。输出一个HTML文档

代码修改为:

d=difflib.HtmlDiff()

print
d.make_file(text1_lines,text2_lines)

make_file得到的是html代码。将代码copy到文件中。打开得到的结果如下:

下面来介绍另一个比较模块:filecmp

当进行代码文件审查时,往往要检查原始与目标文件的一致性。包括修改时间,访问时间等等。这里就要用到filecmp。

1
首先来看下单文件对比:

def
file_cmp_try():

print
'test os.stat result %s' % os.stat('/home/zhf/zhf/test.txt')
#打印出os.stat的结果

print
'test1 os.stat result %s' % os.stat('/home/zhf/zhf/test1.txt')

print
filecmp.cmp('/home/zhf/zhf/test.txt','/home/zhf/zhf/test1.txt')

if
__name__=="__main__":

file_cmp_try()

test
os.stat result posix.stat_result(st_mode=33204, st_ino=6036599L,
st_dev=2049, st_nlink=1, st_uid=1000, st_gid=1000, st_size=145L,
st_atime=1501998994, st_mtime=1501998985, st_ctime=1501998986)
#test的os.stat结果

test1
os.stat result posix.stat_result(st_mode=33204, st_ino=6037307L,
st_dev=2049, st_nlink=1, st_uid=1000, st_gid=1000, st_size=154L,
st_atime=1501998992, st_mtime=1501998920, st_ctime=1501998920)
#test1的os.stat结果

False

cmp会根据os.stat的结果来进行比较,如果相等则会返回True,不相等则返回False。
另外cmp还有一个参数shallow.
这个参数默认为True表示不对文件内容进行对比。如果为False
则会对文件内容也进行比较。

2
多文件对比filecmp.cmpfiles

def
file_cmp_try():

print
filecmp.cmpfiles('/home/zhf/zhf','/home/zhf/zhf/python_prj',['test.txt','chapter1.py'])

if
__name__=="__main__":

file_cmp_try()

结果为3个列表,分别表示匹配,不匹配,错误。错误列表包括了目录中不存在的文件,不具备读权限或其他原因导致的不能比较的文件清单。从下面的结果来看都是在错误的列表。原因在于/home/zhf/zhf/python_prj中并没有包含chapter1.py

([],
[], ['test.txt', 'chapter1.py'])

3目录比较:

tree命令可以直观的查看文件路径的结构,但是不能进行对比输出

p { margin-bottom: 0.25cm; line-height: 120% }
a:link { }

def file_cmp_try():

dir_ret=filecmp.dircmp('/home/zhf/zhf/python_prj','/home/zhf/zhf/python_source')

print dir_ret.report()

if
__name__=="__main__":

file_cmp_try()

输出结果:report
中输出了哪些是路径下特有的文件。

diff
/home/zhf/zhf/python_prj /home/zhf/zhf/python_source

Only
in /home/zhf/zhf/python_prj : ['auto_manintance', 'test.py']

Only
in /home/zhf/zhf/python_source : ['Django-1.10.3',
'Django-1.10.3.tar.gz', 'curl-7.36.0', 'curl-7.36.0.tar.gz',
'dnspython-1.9.4', 'dnspython-1.9.4.tar.gz', 'psutil-2.0.0',
'psutil-2.0.0.tar.gz', 'pycurl-7.19.3.1', 'pycurl-7.19.3.1.tar.gz',
'scapy-2.2.0', 'scapy-2.2.0.tar.gz']

None

二:发送 邮件

电子邮件是现在工作中不可缺少的工具。在自动化和运维上,也常常用邮件来发送告警信息,业务质量报表等。电子邮件的协议主要有SMTP,POP3

SMTP 的全称是“Simple Mail Transfer Protocol”,即简单邮件传输协议。它是一组用于从源地址到目的地址传输邮件的规范,通过它来控制邮件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。SMTP 服务器就是遵循 SMTP 协议的发送邮件服务器。

POP3是Post
Office Protocol
3的简称,即邮局协议的第3个版本,它规定怎样将个人计算机连接到Internet的邮件服务器和下载电子邮件的电子协议。它是因特网电子邮件的第一个离线协议标准,POP3允许用户从服务器上把邮件存储到本地主机(即自己的计算机)上,同时删除保存在邮件服务器上的邮件,而POP3服务器则是遵循POP3协议的接收邮件服务器,用来接收电子邮件的

看了上面的介绍。可以看出SMTP是发送邮件的,POP3是接受邮件的。首先来看下python发送邮件的几个步骤和调用的模块。python调用smtplib模块来进行邮件发送。

主要是下面的几个步骤:

1
SMTP.connect(host,port):
远程连接smtp主机,其中host为主机地址,port为端口。这个主机地址不是我们在浏览器中输入的mail.163.com这种地址,而是像smtp.163.com或者smtp.qq.com.
端口都是默认的25

2
SMTP.login(user,password):参数为用户名和密码

3
SMTP.sendmail(from_addr,to_addr, msg):
其中from_addr是发件人,to_addr是收件人。msg是邮件正文。

4
SMTP.quit():断开smtp服务器的连接。

来看一个具体的实例:

def
send_email():

server='smtp.163.com'

from_addr='maple412@163.com'

to_addr='179039149@qq.com'

username='xxxxx

password='xxxxx'

subject='python
send email test'

content='just
for test'

msg=MIMEText(content)

msg['Subject']=Header(subject)

msg['From']=from_addr

msg['To']=to_addr
#可以是多个收件地址,每个地址间用,分开即可

smtp=smtplib.SMTP()

smtp.connect(server)

smtp.login(username,password)

smtp.sendmail(from_addr,to_addr,msg.as_string())

查看邮件,收到一封来自163的邮件

p { margin-bottom: 0.25cm; line-height: 120% }
a:link { }

上面的邮件只是发送的一个普通的文本字符。如果我们想发送一个网页版的该如何操作呢。其实只需要修改下MIMEText中的内容即可。总共需要两次代码需要修改。将网页代码复给content

content='''<html><body><h1>Hello python</h1><p>send by <a href="http://www.python.org">python</a></p></body></html>

'''

msg=MIMEText(content,'html') #MIMEText中第二个参数赋值为html。参数默认为plain.

邮件效果如下图:

p { margin-bottom: 0.25cm; line-height: 120% }
a:link { }

接下来再看下邮件中带附件:带附件的邮件可以被看做包含若干部分的邮件。文本和各个附件本身。所以可以构造一个MIMEMultipart来代表邮件。然后往里面加上一个MIMEText作为邮件正文。再继续往里面加上表示附件的MIMEApplication对象就可以了

server='smtp.163.com'

from_addr='maple412@163.com'

to_addr='179039149@qq.com'

username='xxxxxxx'

password='xxxxxxx'

subject='python send email test'

msg=MIMEMultipart() #在这里,msg是一个多部分组成的

msg['Subject']=subject

msg['From']=from_addr

msg['To']=to_addr

att1=MIMEApplication(open('/home/zhf/zhf/test.txt','rb').read())

att1.add_header('Content-Disposition','attachment',filename='test.txt')

msg.attach(att1)

try:

smtp=smtplib.SMTP()

smtp.connect(server)

smtp.login(username,password)

smtp.sendmail(from_addr,to_addr,msg.as_string())

smtp.quit()

except BaseException,e:

print e

效果如下。

p { margin-bottom: 0.25cm; line-height: 120% }
a:link { }

当然
也可以既然发送截图,有发送正文。只需要另外再加上一个MIMEText就可以了:

att2=MIMEText(content,'html')

msg.attach(att2)

同样的这个附件可以是XLSX,jpg以及MP3的文件。

在定制报表的时候,经常在邮件正文中发送图片。我们来看下这是如何实现的:

def
send_email_with_picture():

server='smtp.163.com'

from_addr='maple412@163.com'

to_addr='179039149@qq.com'

username='xxxxxxxxx'

password='xxxxxxxxx'

subject='python
send email test'

content='''<html><body><h1>Hello
python</h1><img src="cid:io"></body></html>

'''

#在网页代码中,src=”cid:io”,网页中嵌入图片是通过cid来索引到具体的图片,在这里cid引用的是io的图片。

msg=MIMEMultipart()

msg['Subject']=subject

msg['From']=from_addr

msg['To']=to_addr

p=open('/home/zhf/Pictures/1.jpg','rb')

msgimage=MIMEImage(p.read())
#创建一个图片对象

p.close()

msgimage.add_header('Content-ID','io')
#在这里设置图片对象的cid为io.
便于被网页代码引用

msg.attach(msgimage)

msgtext=MIMEText(content,'html','utf-8')

msg.attach(msgtext)

try:

smtp=smtplib.SMTP()

smtp.connect(server)

smtp.login(username,password)

smtp.sendmail(from_addr,to_addr,msg.as_string())

smtp.quit()

except
BaseException,e:

print
e

效果如下:

p { margin-bottom: 0.25cm; line-height: 120% }
a:link { }

最后介绍一个web监控函数:pycurl. 这相当于Linux命令curl的python实现

def web_detect_function():

url="www.sina.com.cn"

c=pycurl.Curl()

c.setopt(pycurl.URL,url)

c.setopt(pycurl.CONNECTTIMEOUT,5)

c.setopt(pycurl.TIMEOUT,5)

c.setopt(pycurl.NOPROGRESS,1)

c.setopt(pycurl.FORBID_REUSE,1)

c.setopt(pycurl.MAXREDIRS,1)

c.setopt(pycurl.DNS_CACHE_TIMEOUT,30)

#setopt是设置各项下载的参数

try:

c.perform()

except Exception,e:

print e

NAMELOOKUP_TIME=c.getinfo(c.NAMELOOKUP_TIME)

CONNECT_TIME=c.getinfo(c.CONNECT_TIME)

TOTAL_TIME=c.getinfo(c.TOTAL_TIME)

HTTP_CODE=c.getinfo(c.HTTP_CODE)

HEADER_SIZE=c.getinfo(c.HEADER_SIZE)

SPEED_DOWNLOAD=c.getinfo(c.SPEED_DOWNLOAD)

#getinfo是得到网页浏览的各项参数

print 'NAMELOOKUP TIME:%d' % NAMELOOKUP_TIME

print 'CONNECT TIME:%d' % CONNECT_TIME

print 'TOTAL TIME:%d' % TOTAL_TIME

print 'HTTP_CODE:%s' % HTTP_CODE

print 'HEADER_SIZE:%d' % HEADER_SIZE

print 'SPEED_DOWNLOAD:%d' % SPEED_DOWNLOAD

c.close()

运行结果:

NAMELOOKUP
TIME:0

CONNECT
TIME:0

TOTAL
TIME:0

HTTP_CODE:200

HEADER_SIZE:709

SPEED_DOWNLOAD:1145386

python自动化运维二:业务服务监控的更多相关文章

  1. python自动化运维之CMDB篇-大米哥

    python自动化运维之CMDB篇 视频地址:复制这段内容后打开百度网盘手机App,操作更方便哦 链接:https://pan.baidu.com/s/1Oj_sglTi2P1CMjfMkYKwCQ  ...

  2. Python自动化运维:技术与最佳实践 PDF高清完整版|网盘下载内附地址提取码|

    内容简介: <Python自动化运维:技术与最佳实践>一书在中国运维领域将有“划时代”的重要意义:一方面,这是国内第一本从纵.深和实践角度探讨Python在运维领域应用的著作:一方面本书的 ...

  3. Python自动化运维 技术与最佳实践PDF高清完整版免费下载|百度云盘|Python基础教程免费电子书

    点击获取提取码:7bl4 一.内容简介 <python自动化运维:技术与最佳实践>一书在中国运维领域将有"划时代"的重要意义:一方面,这是国内第一本从纵.深和实践角度探 ...

  4. 【目录】Python自动化运维

    目录:Python自动化运维笔记 Python自动化运维 - day2 - 数据类型 Python自动化运维 - day3 - 函数part1 Python自动化运维 - day4 - 函数Part2 ...

  5. python自动化运维篇

    1-1 Python运维-课程简介及基础 1-2 Python运维-自动化运维脚本编写 2-1 Python自动化运维-Ansible教程-Ansible介绍 2-2 Python自动化运维-Ansi ...

  6. Day1 老男孩python自动化运维课程学习笔记

    2017年1月7日老男孩python自动化运维课程正式开课 第一天学习内容: 上午 1.python语言的基本介绍 python语言是一门解释型的语言,与1989年的圣诞节期间,吉多·范罗苏姆为了在阿 ...

  7. python自动化运维学习第一天--day1

    学习python自动化运维第一天自己总结的作业 所使用到知识:json模块,用于数据转化sys.exit 用于中断循环退出程序字符串格式化.format字典.文件打开读写with open(file, ...

  8. Python自动化运维的职业发展道路(暂定)

    Python职业发展之路 Python自动化运维工程 Python基础 Linux Shell Fabric Ansible Playbook Zabbix Saltstack Puppet Dock ...

  9. Python自动化运维开发实战 一、初识Python

    导语 都忘记是什么时候知道python的了,我是搞linux运维的,早先只是知道搞运维必须会shell,要做一些运维自动化的工作,比如实现一些定时备份数据啊.批量执行某个操作啊.写写监控脚本什么的. ...

随机推荐

  1. Python爬虫小白---(二)爬虫基础--Selenium PhantomJS

    一.前言   前段时间尝试爬取了网易云音乐的歌曲,这次打算爬取QQ音乐的歌曲信息.网易云音乐歌曲列表是通过iframe展示的,可以借助Selenium获取到iframe的页面元素, 而QQ音乐采用的是 ...

  2. java volatitle介绍与使用

    关于关键字volatile可以说是Java虚拟机提供的轻量级的同步机制,但是它并不容易完全被正常.完整地理解,以至于许多程序员都不习惯去使用它,遇到需要处理多线程数据竞争问题的时候一律使用Synchr ...

  3. sleep() 和 wait() 有什么区别?

    sleep()方法是使线程停止一段时间的方法.在sleep 时间间隔期满后,线程不一定立即恢复执行.这是因为在那个时刻,其它线程可能正在运行而且没有被调度为放弃执行,除非"醒来"的 ...

  4. MongoDB 安装和配置

    [前言] Mongodb是一款nosql数据库,关于nosql 以及 mongodb本文不进行介绍,在数据库的选型方面,本人说是在机缘巧合之下选择了mongodb,并且拟使用mongodb搭建日志系统 ...

  5. FreeRTOS——错误排查

    1. printf-stdarg.c 在调用标准库函数时,栈空间的用量可能急剧上升,特别是IO与字符串处理函数,比如 sprintf(). 在FreeRTOS下载包中有一个名为printf-stdar ...

  6. 使用Spring boot + jQuery上传文件(kotlin)

    文件上传也是常见的功能,趁着周末,用Spring boot来实现一遍. 前端部分 前端使用jQuery,这部分并不复杂,jQuery可以读取表单内的文件,这里可以通过formdata对象来组装键值对, ...

  7. MD5加密Demo

    package com.util; import java.security.MessageDigest; public class MD5 { public final static String ...

  8. 国内网站遭遇SYN攻击事如何及时解决问题

    1.SYN/ACK Flood攻击:这种攻击方法是经典最有效的DDOS方法,可通杀各种系统的网络服 务,主要是通过向受害主机发送大量伪造源IP和源端口的SYN或ACK包,导致主机的缓存资源被耗 尽或忙 ...

  9. .Net Core 系列:2、ADO.Net 基础

    目录: 1.环境搭建 2.ADO.Net 基础 3.ASP.Net Core 基础 4.MD5.Sha256.AES 加密 5.实现登录注册功能 6.实现目录管理功能 7.实现文章发布.编辑.阅览和删 ...

  10. NLP —— 图模型(一)隐马尔可夫模型(Hidden Markov model,HMM)

    本文简单整理了以下内容: (一)贝叶斯网(Bayesian networks,有向图模型)简单回顾 (二)隐马尔可夫模型(Hidden Markov model,HMM) 写着写着还是写成了很规整的样 ...