Python之——生成动态路由轨迹图的实例


Posted in Python onNovember 22, 2019

一、scapy简介与安装

scapy(http://www.secdev.org/projects/scapy/)是一个强大的交互式数据包处理程序,它能够对数据包进行伪造或解包,包括发送数据包、包嗅探、应答和反馈匹配等功能。可以用在处理网络扫描、路由跟踪、服务探测、单元测试等方面,本节主要针对scapy的路由跟踪功能,实现TCP协议方式对服务可用性的探测,比如常用的80(HTTP)与443(HTTPS)服务,并生成美观的路由线路图报表,让管理员清晰了解探测点到目标主机的服务状态、骨干路由节点所处的IDC位置、经过的运营商路由节点等信息。

下面详细进行介绍。

scapy模块的安装方法如下:

# scapy模板需要tcpdump程序支持,生成报表需要graphviz、ImageMagick图像处理包支持
# yum -y install tcpdump graphviz ImageMagick
# 源码安装
# wget http://www.secdev.org/projects/scapy/files/scapy-2.2.0.tar.gz
# tar -zxvf scapy-2.2.0.tar.gz
# cd scapy-2.2.0
# python setup.py install

二、scapy模块常用方法说明

scapy模块提供了众多网络数据包操作的方法,包括发包send()、SYN\ ACK扫描、嗅探sniff()、抓包wrpcap()、TCP路由跟踪traceroute()等,本节主要关注服务监控内容接下来详细介绍traceroute()方法,其具体定义如下:

traceroute(target, dport=80, minttl=1, maxttl=30, sport=<RandShort>, l4=None, filter=None, timeout=2, verbose=None, **kargs)

该方法实现TCP跟踪路由功能,关键参数说明如下:

target:跟踪的目标对象,可以是域名或IP,类型为列表,支持同时指定多个目标,如["www.qq.com","www.baidu.com",www.google.com.hk];

dport:目标端口,类型为列表,支持同时指定多个端口,如[80,443];

minttl:指定路由跟踪的最小跳数(节点数);

maxttl:指定路由跟踪的最大跳数(节点数)。

三、基于TCP实现探测目标服务路由轨迹

Python之——生成动态路由轨迹图的实例

在此次实践中,通过scapy的traceroute()方法实现探测机到目标服务器的路由轨迹,整个过程的原理如下图,首先通过探测机以SYN方式进行TCP服务扫描,同时启动tcpdump进行抓包,捕获扫描过程经过的所有路由点,再通过graph()方法进行路由IP轨迹绘制,中间调用ASN映射查询IP地理信息并生成svg流程文档,最后使用ImageMagick工具将svg格式转换成png,流程结束。

本次实践通过traceroute()方法实现路由的跟踪,跟踪结果动态生成图片格式。功能实现源码如下:

# -*- coding: utf-8 -*-
import os,sys,time,subprocess
import warnings,logging
warnings.filterwarnings("ignore", category=DeprecationWarning) #屏蔽scapy无用告警信息
logging.getLogger("scapy.runtime").setLevel(logging.ERROR) #屏蔽模块IPv6多余告警
from scapy.all import traceroute
 
domains = raw_input('Please input one or more IP/domain: ') #接受输入的域名或IP
target = domains.split(' ')
dport = [80]  #扫描的端口列表
 
if len(target) >= 1 and target[0]!='':
  res,unans = traceroute(target,dport=dport,retry=-2) #启动路由跟踪
  res.graph(target="> test.svg")  #生成svg矢量图形
  time.sleep(1)
  subprocess.Popen("/usr/bin/convert test.svg test.png", shell=True) #svg转png格式
else:
  print "IP/domain number of errors,exit"

代码运行结果如下图所示,“-”表示路由节点无回应或超时;“11”表示扫描的指定服务无回应;“SA”表示扫描的指定服务有回应,一般是最后一个主机IP。

Python之——生成动态路由轨迹图的实例

生成的路由轨迹图如下图(仅局部),“-”将使用unk*单元代替,重点路由节点将通过ASN获取所处的运营商或IDC位置,如IP“202.102.69.210”为“CHINANET-JS-AS-AP AS Number for CHINANET jiangsu province backbone,CN”意思为该IP所处中国电信江苏省骨干网。

Python之——生成动态路由轨迹图的实例

通过路由轨迹图,我们可以非常清晰地看到探测点到目标节点的路由走向,运营商时常会做路由节点分流,不排除会造成选择的路由线路不是最优的,该视图可以帮助我们了解到这个信息。另外IE8以上及chrome浏览器都已支持SVG格式文件,可以直接浏览,无需转换成png或其他格式,可以轻松整合到我们的运营平台当中。

本文出自《Python自动化运维 技术与最佳实践》

以上这篇Python之——生成动态路由轨迹图的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
研究Python的ORM框架中的SQLAlchemy库的映射关系
Apr 25 Python
python分布式环境下的限流器的示例
Oct 26 Python
11个Python Pandas小技巧让你的工作更高效(附代码实例)
Apr 30 Python
Python学习笔记之自定义函数用法详解
Jun 08 Python
python自定义时钟类、定时任务类
Feb 22 Python
python try except返回异常的信息字符串代码实例
Aug 15 Python
python 模拟创建seafile 目录操作示例
Sep 26 Python
python函数不定长参数使用方法解析
Dec 14 Python
运行tensorflow python程序,限制对GPU和CPU的占用操作
Feb 06 Python
python创建文本文件的简单方法
Aug 30 Python
selenium判断元素是否存在的两种方法小结
Dec 07 Python
Python中zipfile压缩包模块的使用
May 14 Python
python:动态路由的Flask程序代码
Nov 22 #Python
python判断无向图环是否存在的示例
Nov 22 #Python
python计算无向图节点度的实例代码
Nov 22 #Python
Python字符串格式化输出代码实例
Nov 22 #Python
python常用数据重复项处理方法
Nov 22 #Python
Python pickle模块实现对象序列化
Nov 22 #Python
python绘制无向图度分布曲线示例
Nov 22 #Python
You might like
改造一台复古桌面收音机
2021/03/02 无线电
PHP入门速成(2)
2006/10/09 PHP
PHP 在数组中搜索给定的简单实例 array_search 函数
2016/06/13 PHP
javascript基础的动画教程,直观易懂
2007/01/10 Javascript
JavaScript与Image加载事件(onload)、加载状态(complete)
2011/02/14 Javascript
jquery对表单操作2
2011/04/06 Javascript
document.documentElement和document.body区别介绍
2013/09/16 Javascript
javascript特殊用法示例介绍
2013/11/29 Javascript
js动态改变select选择变更option的index值示例
2014/07/10 Javascript
js中的事件捕捉模型与冒泡模型实例分析
2015/01/10 Javascript
JS获取数组最大值、最小值及长度的方法
2015/11/24 Javascript
浅谈jQuery animate easing的具体使用方法(推荐)
2016/06/17 Javascript
jQuery如何封装输入框插件
2016/08/19 Javascript
微信小程序 后台https域名绑定和免费的https证书申请详解
2016/11/10 Javascript
使用jsonp实现跨域获取数据实例讲解
2016/12/25 Javascript
Angular.JS去掉访问路径URL中的#号详解
2017/03/30 Javascript
Vuex之理解Store的用法
2017/04/19 Javascript
详解Node.js串行化流程控制
2017/05/04 Javascript
vue项目中v-model父子组件通信的实现详解
2017/12/10 Javascript
AngularJS 多指令Scope问题的解决
2018/10/25 Javascript
jQuery实现文本显示一段时间后隐藏的方法分析
2019/06/20 jQuery
使用Promise封装小程序wx.request的实现方法
2019/11/13 Javascript
Javascript var变量删除原理及实现
2020/08/26 Javascript
Vue实现Header渐隐渐现效果的实例代码
2020/11/05 Javascript
Python实现的计算器功能示例
2018/04/26 Python
Python3 集合set入门基础
2020/02/10 Python
python 删除系统中的文件(按时间,大小,扩展名)
2020/11/19 Python
Nike意大利官网:Nike.com IT
2020/01/19 全球购物
工程造价管理专业大专生求职信
2013/10/06 职场文书
学习雷锋精神心得体会范文
2014/03/12 职场文书
协会周年庆活动方案
2014/08/26 职场文书
普通党员四风问题对照检查材料
2014/09/27 职场文书
党员个人总结自评
2015/02/14 职场文书
致创业的您:这类人不适合餐饮创业
2019/08/19 职场文书
解决Jupyter-notebook不弹出默认浏览器的问题
2021/03/30 Python
python处理json数据文件
2022/04/11 Python