python自动化运维笔记2 —— IP地址处理模块IPy
1.2 实用的IP地址处理模块IPy
ip地址规划是网络设计中非常重要的一个环节,规划的好坏会直接影响路由协议算法的效率,包括网络性能、可扩展性等方面,在这个过程当中,免不了要计算大量的IP地址,包括网段、网络掩码、广播地址、子网数、IP类型等。python提供了一个强大的第三方模块IPy,IPy模块可以很好地辅助我们高效完成IP的规划工作。
IPy模块源码包的安装方法如下:
wget https://pypi.python.org/packages/source/I/IPy/IPy-0.83.tar.gz
tar -xf IPy-0.83.tar.gz
cd IPy-0.83
python setup.py install
1.2.1 IP地址、网段的基本处理
IP模块包含IP类,使用它可以方便处理绝大部分格式为IPv4及IPv6的网络和地址
比如通过version方法就可以区分出IPv4和IPv6
>>> from IPy import IP
>>> IP('10.0.0.0/8').version() >>> IP('::1').version()
通过指定的网段输出该网段的IP个数及所有IP地址清单,如下:
#!/usr/bin/env python
#encoding:utf8 #python2版本必须加编码类型,否则会报错
from IPy import IP
ip=IP('192.168.0.0/16')
print ip.len() #输出该网段的IP个数
for x in ip: #输出该网段的所有IP
print(x)
下面介绍IP类几个常见的方法,包括方向解析、IP类型、IP转换等
>>> from IPy import IP
>>> ip=IP('192.168.1.20')
>>> ip.reverseNames() #反向解析地址格式
['20.1.168.192.in-addr.arpa.']
>>> ip.iptype() #ip地址类型
'PRIVATE' #私网
>>> IP('8.8.8.8').iptype() #8.8.8.8为公网类型
'PUBLIC'
>>> IP('8.8.8.8').int() #转换成整型格式 >>> IP('8.8.8.8').strHex() #转换成十六进制格式
'0x8080808'
>>> IP('8.8.8.8').strBin() #转换为二进制格式
''
>>> print(IP(0x8080808)) #十六进制转成IP格式
8.8.8.8
IP方法也支持网络地址的转换,例如根据IP与掩码生产网络
>>> from IPy import IP
>>> print(IP('192.168.1.0').make_net('255.255.255.0'))
192.168.1.0/
>>> print(IP('192.168.1.0/255.255.255.0',make_net=True))
192.168.1.0/
>>> print(IP('192.168.1.0-192.168.1.255',make_net=True))
192.168.1.0/
也可以通过strNormal方法指定不同wantprefixlen参数值以定制不同输出类型的网段。输出类型为字符串
>>> IP('192.168.1.0/24').strNormal()
'192.168.1.0'
>>> IP('192.168.1.0/24').strNormal()
'192.168.1.0/24'
>>> IP('192.168.1.0/24').strNormal()
'192.168.1.0/255.255.255.0'
>>> IP('192.168.1.0/24').strNormal()
'192.168.1.0-192.168.1.255'
wantprefixlen的取值及含义:
1)wantprefixlen=0,无返回,如192.168.1.0;
2)wantprefixlen=1,prefix格式,如192.168.1.0/24;
3)wantprefixlen=2,decimalnetmask格式,如192.168.1.0/255.255.255.0;
4)wantprefixlen=3,lastIP格式,如192.168.1.0-192.168.1.255。
1.2.2 多网络计算方法详解
有时候我们想比较两个网段是否存在包含、重叠等关系,比如同网络但不同prefixlen会认为是不相等的网段,如10.0.0.0/16不等于10.0.0.0/24,另外即使具有相同的prefixlen但处于不同的网络地址,同样也视为不相等,如10.0.0.0/16不等于192.0.0.0/16。IPy支持类似于数值型数据的比较,以帮助IP对象进行比较,如:
>>> IP('10.0.0.0/24') < IP('12.0.0.0/24')
True
判断IP地址和网段是否包含与另一个网段中,如下:
>>> '192.168.1.100' in IP('192.168.1.0/24')
True
>>> IP('192.168.1.0/24') in IP('192.168.0.0/16')
True
>>> '192.168.1.0/24' in IP('192.168.0.0/16')
True
判断两个网段是否存在重叠,采用IPy提供的overlaps方法,如:
>>> IP('192.168.0.0/23').overlaps('192.168.1.0/24')
#1表示存在重叠
>>> IP('192.168.1.0/24').overlaps('192.168.2.0')
#0表示不存在重叠
示例:根据输入的IP或子网返回网络、掩码、广播、反向解析、子网数、IP类型等信息。
#!/usr/bin/env python
#coding:utf8
from IPy import IP ip_s=raw_input('please input an IP or net-range:') #接受用户输入,参数>为IP地址或网段地址
ips=IP(ip_s)
if (len(ips)>1): #为一个网络地址
print('net: %s' %ips.net()) #输出网络地址
print('broadcast: %s' %ips.broadcast()) #输出广播地址
print('network: %s' %ips.netmask()) #输出掩码地址
print('reverse address: %s' %ips.reverseNames()[0]) #输出IP反向解析
print('subnet: %s' %len(ips)) #输出网络子网数
else: #为单个IP地址
print('reverse address: %s' %ips.reverseNames()[0]) #输出IP反向解析
print('hexadecimal: %s' %ips.strHex()) #输出十六进制地址
print('binary ip: %s' %ips.strBin()) #输出二进制地址
print('iptype: %s' %ips.iptype()) #输出地址类型
[root@localhost danny]# python a.py
please input an IP or net-range:192.168.1.1
reverse address: 1.1.168.192.in-addr.arpa.
hexadecimal: 0xc0a80101
binary ip:
iptype: PRIVATE [root@localhost danny]# python a.py
please input an IP or net-range:192.168.1.0/
net: 192.168.1.0
broadcast: 192.168.1.255
network: 255.255.255.0
reverse address: 1.168..in-addr.arpa.
subnet:
python自动化运维笔记2 —— IP地址处理模块IPy的更多相关文章
- python自动化运维笔记3 —— dns处理模块dnspython
1.3 DNS处理模块 dnspython是python实现的一个DNS工具包,它支持几乎所有的记录类型,可以用于查询.传输并动态更新ZONE信息,同时支持TSIG(事物签名)验证消息和EDNS0(扩 ...
- python自动化运维笔记1 —— 系统性能信息模块psutil
一.系统基础信息模块 1.1 系统性能信息模块psutil psutil是一个跨平台库(http://code.google.com/p/psutil/),能够轻松实现获取系统运行的进程和系统利用率( ...
- Python自动化运维之8、正则表达式re模块
re模块 正则表达式使用单个字符串来描述.匹配一系列符合某个句法规则的字符串,在文本处理方面功能非常强大,也经常用作爬虫,来爬取特定内容,Python本身不支持正则,但是通过导入re模块,Python ...
- 【目录】Python自动化运维
目录:Python自动化运维笔记 Python自动化运维 - day2 - 数据类型 Python自动化运维 - day3 - 函数part1 Python自动化运维 - day4 - 函数Part2 ...
- Python自动化运维:技术与最佳实践 PDF高清完整版|网盘下载内附地址提取码|
内容简介: <Python自动化运维:技术与最佳实践>一书在中国运维领域将有“划时代”的重要意义:一方面,这是国内第一本从纵.深和实践角度探讨Python在运维领域应用的著作:一方面本书的 ...
- Day1 老男孩python自动化运维课程学习笔记
2017年1月7日老男孩python自动化运维课程正式开课 第一天学习内容: 上午 1.python语言的基本介绍 python语言是一门解释型的语言,与1989年的圣诞节期间,吉多·范罗苏姆为了在阿 ...
- python自动化运维之CMDB篇-大米哥
python自动化运维之CMDB篇 视频地址:复制这段内容后打开百度网盘手机App,操作更方便哦 链接:https://pan.baidu.com/s/1Oj_sglTi2P1CMjfMkYKwCQ ...
- python自动化运维学习第一天--day1
学习python自动化运维第一天自己总结的作业 所使用到知识:json模块,用于数据转化sys.exit 用于中断循环退出程序字符串格式化.format字典.文件打开读写with open(file, ...
- Python自动化运维技术与最佳实现
第一章 系统基础信息模块详解 系统基础信息采集模块最为监控模块的重要组成部分,能够帮助运维人员了解当前系统的健康程度,同时也是衡量业务的服务质量的依据,比如系统资源吃紧,会直接影响业务的质量以及用户的 ...
随机推荐
- solidity fallback函数
什么是fallback函数: 出处:http://me.tryblockchain.org/blockchain-solidity-fallback.html 回退函数是合约里的特殊函数,没有名字,不 ...
- WebSphere下配置HTTP压缩
WebSphere下配置HTTP压缩 背景 WebSphere本身的安装配置中并不包含HTTP压缩的模块,而是通过新增WebServer来实现的,WebSphere通过Plugin与WebServer ...
- 洛谷 P1396 营救
题目链接 https://www.luogu.org/problemnew/show/P1396 题目描述 “咚咚咚……”“查水表!”原来是查水表来了,现在哪里找这么热心上门的查表员啊!小明感动的热泪 ...
- Java多线程编程模式实战指南一:Active Object模式(下)
Active Object模式的评价与实现考量 Active Object模式通过将方法的调用与执行分离,实现了异步编程.有利于提高并发性,从而提高系统的吞吐率. Active Object模式还有个 ...
- python多版本共存问题(以2.7和3.5系列版本为例)
1.0 下载Python2.7x和Python3.5x版本 2.0 安装Python 3.0 配置环境变量,分别添加至path路径 4.0 只修改Python27文件中的.exe文件(这样系统默认为P ...
- PHP实现栈数据结构
利用php面向对象思想,栈的属性有top.最大存储数.和存储容器(这里利用了php数组). 代码如下:实现了入栈.出栈.遍历栈的几个方法: <?php class Stack{ const MA ...
- 利用数据库触发器让字段与自增长Id相关联
十年河东,十年河西,莫欺少年穷 学无止境,精益求精 今天是数据库脚本类的代码,所以不想过多阐述 如下数据表: create table Card( Id ,) primary key, CardNo ...
- Luogu P3398 仓鼠找sugar
这还是一道比较好的树剖题(去你的树剖,LCA即可) 这里主要讲两种思路,其实都是很基本也很经典的 1 树链剖分 还是先讲一下这种算法吧,虽然写起来很烦(不过感觉写多了就习惯了,而且还有一种莫名的快感) ...
- 分布式系统session一致性的问题
session的概念 什么是session? 服务器为每个用户创建一个会话,存储用户的相关信息,以便多次请求能够定位到同一个上下文.这样,当用户在应用程序的 Web 页之间跳转时,存储在 Sessio ...
- 深入理解USB流量数据包的抓取与分析
0x01 问题提出 在一次演练中,我们通过wireshark抓取了一个如下的数据包,我们如何对其进行分析? 0x02 问题分析 流量包是如何捕获的? 首先我们从上面的数据包分析可以知道,这是个USB的 ...