python运维脚本windows_运维:windows+python+route的一次相遇

自言自语

作为一名网络运维工程师,自从接触了linux就被脚本语言所着迷。从Shell到java到expect再到python,慢慢的变得习惯用写运维工具的方式来解决日常运维问题。

本次写的运维工具让我get到了很多新技能,觉得很有必要把思绪、过程详细的记录下来,以便日后回顾复习。该工具其实就是一个在windows上用来检测路由的python程序。我是python小菜鸡,请各路大神多指教!

功能说明:

每天凌晨4点从远端服务器获取指定的调度域名列表,对调度域名逐个进行解析。对解析结果中的每个IP进行tracert路径跟踪。若路径中未经过指定出口节点,则判定为检测失败。将检测失败的域名对应的IP写进邮件正文。若邮件正文内容不为空,代表有检测到失败的域名,发送邮件到指定运维人员邮箱。

实现思路:

1、linux中要实现每天凌晨4点执行一个程序,使用contab会很方便。但在windows系统要实现定期执行,就要用到windows自带的任务与计划(让程序每执行一次,休眠24小时也能实现,但效果肯定没任务与计划好和灵活);

2、利用wget方式从远端服务器获取调度域名列表(感觉wget比ftp\tftp要来的更强大一丁丁),剩下的解析、检测、发送邮件等用python脚本实现。选择python是因为python脚本也可以在linux系统上使用方便后期调整。(感觉cygwin运行shell脚本或java都没有python来的方便);实现过程:

1、在远端服务器1.1.1.1上放好指定调度域名列表,开启Apache服务[root@keerhe ~]# cat /var/www/html/diaodu.txt

data.video.qiyi.com

g3.letv.com

k.youku.com

pl.youku.com

data.vod.itc.cn

v2.tudou.com

ips.ifeng.com

v.iask.com

wtv.v.iask.com

vv.video.qq.com

zb.v.qq.com

2、利用python获取调度域名列表,并完成解析、检测等一系列功能# coding:utf-8

"""文档说明:

该软件用于调度自动检测

1、从服务器wget调度域名列表文件

2、从文件中读取调度域名并逐个tracert

3、判断tracert结果,若路径中包含30.207.4.250表示调度正常

4、若不正常,触发告警,发出告警邮件

5、在windows的任务与计划中,每天定期执行python脚本

6、运行日志直接输出在cmd窗口(可选)

"""

#-----重要:将'节点名称'改成相应的节点名称,如nap='河北'

#----------导入模块-----------

import smtplib

import subprocess,re

from email.mime.text import MIMEText

#----------邮件发送函数-----------

def sendmail(): #定义发送邮件的函数

nap='贵州' #给本机定义个名称,用以收件人区分邮件由哪个测试机发出

sender='IpTracker2' #发件人昵称及邮箱地址

receivers=['yunwei1@watone.com.cn','yunwei2@watone.com.cn','yunwei3@watone.com.cn']

subject=nap+'调度检测发现异常!!!' #邮件标题

smtpserver='smtp.163.com' #发件人邮箱smtp服务器设置

username='xxxxxx@163.com' #发件人邮箱账号

password='123456' #发件人邮箱密码

content="\n".join(detected) #列表detected中每个元素以回车分割,返回一个字符串

print ('异常内容是:'+content) #将content内容打印

msg=MIMEText(content,'text','utf-8')

msg['Subject']=subject

msg['to']=';'.join(receivers) #列表receivers元素以分号分隔

msg['from']=sender

smtp=smtplib.SMTP()

smtp.connect('smtp.163.com')

smtp.login(username,password)

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

smtp.close()

#----------获取调度域名文件-----------

#下载日志记录于wgetlog.txt中,下载文件保存于c:/Python34,以diaodu.txt命令

print ("开始获取文件")

subprocess.call('wget -a wgetlog.txt -O diaodu.txt -P c:\Python34 http://1.1.1.1/diaodu.txt')

print ("文件已更新")

#----------解析调度域名,获取调度IP----------

r_getip=r'\d+\.+\d+\.+\d+\.+\d+' #定义过滤IP地址的正则表达式

file=open("c:\Python34\diaodu.txt") #打开文件

file.seek(0,0) #设置指针到行首

r_watone=r'30.207.4.250|30.207.6.154|10.30.96.10' #定义指定出口的正则表达式

detected=[]

count=1

for name in file: #遍历调度域名列表

name=name.strip('\n') #去除域名后面的\n符号,防止解析错误

resolve=subprocess.getoutput('nslookup '+name) #解析调度域名,将结果保存在resolve

track_ip=re.findall(r_getip,resolve)

track_ip.pop(0) #过滤出resolve中所有的IP地址,并删除第一个IP(第一个IP是DNS地址)

print (name+'解析成功,IP是:')

print (track_ip)

print ('开始对这些IP进行逐个检测,请耐心等候.........')

#---------跟踪调度IP并进行判断---------

for ip in track_ip: #对解析出来的IP遍历

traceroute=subprocess.getoutput('tracert -d '+ip) #保存路径跟踪结果

find=re.findall(r_watone,traceroute)

if len(find)==0: #在路径中搜索出口IP并放入列表find,若长度为0代表没从出口走

detected.append(name+"对应IP:"+ip+"检测失败!")

#将检测到域名及IP放入列表detected中

print ("第"+str(count)+"个域名检测结束!")

count+=1

#-----异常信息整理并发送告警邮件---------

try:

if len(detected)!=0: #若detected列表长度不为0,代表有域名及IP被写入

print ("有发现")

sendmail() #发送告警邮件

print ("邮件已发送!")

else:

print ("本次没有发现异常")

except Exception:

print ("程序有异常")

finally:

close=file.close() #关闭文件

if close is None:

print ("文件关闭成功,检测结束!") #确认文件关闭成功

else:

print ("文件关闭失败,请检查!")

3、为保护文件不被别人误修改,加快脚本执行速度,对python脚本进行编译。将编译后的PYC文件拷贝到c:/Python34目录下,名字改为Iptracker2.pyc>>> import py_compile

>>> py_compile.compile('c:/Python34/IpTracker2.py')

'c:/Python34\\__pycache__\\IpTracker2.cpython-34.pyc'

>>>

4、将wget.exe拷贝到c:/Python34目录,并创建批处理文件auto.bat,方便后面创建任务与计划。用记事本打开auto.bat,写入:cd c:/Python34

python C:\Python34\IpTracker2.pyc

5、创建任务与计划,打开控制面板--管理工具--任务与计划

①、点击页面右上方‘创建任务’

wKiom1aVCNfDVfjrAAB31aCCWqE224.png

②、填写任务名称并选择无论用户是否登录均执行(该种方式运行不会弹出cmd界面,直接后台运行)

wKioL1aVCQmzoz5YAACup1RhbK0343.png

④、新建触发器,选择每天凌晨4点为触发条件

wKioL1aVCQrhoAeFAADw9xMfNQk520.png

⑤、创建动作,执行批处理脚本auto.bat

wKiom1aVCNuBCrt5AACqW2-J7oc981.png

⑥、在设置中将以下两个打勾,防止任务执行失败。点击确认,输入windows密码点击确认

wKiom1aVCNyR1JEGAAB9AqDt4b4596.png

⑦、在任务列表中查看任务IpTracker2状态为就绪,说明创建成功

wKiom1aVCN3jBwS4AAChiXYX1hw815.png成果展示,告警邮件内容:

wKioL1aVEu3CHQdBAAAcHxea65o590.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值