python netifaces模块

简介

在Linux系统中,我们可以通过ifconfig,route等shell命令来查看系统接口配置,网关和路由等信息。通过shell的正则表达式功能,通过系列复杂操作,我们可以从字符串中提取出相关的信息。现在,通过Python的netifaces模块,可以很容易的获取这些信息。本文主要介绍netifaces的使用。

安装

可以在Python官网上去下载对应的源码:https://pypi.python.org/pypi/netifaces。当前的版本是0.10.4。
参考下面的步骤进行安装:
[plain] view plain copy
 
  1. tar xvzf netifaces-0.10.4.tar.gz   
  2. cd netifaces-0.10.4   
  3. sudo python setup.py install  
提示:通过源码安装此模块,需要安装python-dev开发包,可以通过“apt-get install python-dev”进行安装。

使用

netifaces模块使用起来非常简单,我们来逐一介绍其支持的功能特性。

地址类型编码

Netifaces定义了接口地址类型字典,你可以很方便的查询各类地址类型对应的地址类型编码,在后面的介绍中,我们会发现查询结果仅显示接口地址类型编码,可以通过address_families查询地址编码的字符串表示形式。
[python] view plain copy
 
  1. bob@192.168.1.100:~$ python  
  2. Python 2.6.2 (release26-maint, Apr 19 2009, 01:56:41)  
  3. [GCC 4.3.3] on linux2  
  4. Type "help", "copyright", "credits" or "license" for more information.  
  5. >>> import netifaces  
  6. >>> netifaces.address_families  
  7. {0: 'AF_UNSPEC', 1: 'AF_FILE', 2: 'AF_INET', 3: 'AF_AX25', 4: 'AF_IPX',   
  8. 5: 'AF_APPLETALK', 6: 'AF_NETROM', 7: 'AF_BRIDGE', 8: 'AF_ATMPVC', 9: 'AF_X25',   
  9. 10: 'AF_INET6', 11: 'AF_ROSE', 12: 'AF_DECnet', 13: 'AF_NETBEUI', 14: 'AF_SECURITY',   
  10. 15: 'AF_KEY', 16: 'AF_NETLINK', 17: 'AF_PACKET', 18: 'AF_ASH', 19: 'AF_ECONET',   
  11. 20: 'AF_ATMSVC', 22: 'AF_SNA', 23: 'AF_IRDA', 24: 'AF_PPPOX', 25: 'AF_WANPIPE',   
  12. 31: 'AF_BLUETOOTH', 34: 'AF_ISDN'}  

接口查询

[python] view plain copy
 
  1. >>> netifaces.interfaces()  
  2. ['lo', 'eth0', 'eth1', 'eth2_rename', 'vlan11']  

通过interfaces()函数接口,可以很容易的获取系统当前的接口列表。Duang,Duang,Duang,是不是很任性呢。

接口配置查询

我们获取了系统的接口信息后,就可以继续查询指定接口的地址配置信息。
[python] view plain copy
 
  1. >>> netifaces.ifaddresses('eth0')  
  2. {17: [{'broadcast': 'ff:ff:ff:ff:ff:ff', 'addr': '00:0c:29:3e:6b:c8'}],   
  3. 2: [{'broadcast': '10.220.33.255', 'netmask': '255.255.255.0', 'addr': '10.220.33.101'}],   
  4. 10: [{'netmask': 'ffff:ffff:ffff:ffff::', 'addr': 'fe80::20c:29ff:fe3e:6bc8%eth0'}]}  
使用ifaddresses()接口,可以这么容易的获取接口的地址配置信息,返回的信息以字典的形式返回。每一项都指向了一个特定的地址簇配置,如
[python] view plain copy
 
  1. 2: [{'broadcast': '10.220.33.255', 'netmask': '255.255.255.0', 'addr': '10.220.33.101'}]  

地址类型为2,查询address_families,我们可以知道它是AF_INET的类型,是关于IPv4的配置。在你实际使用中,不要直接使用2这种魔数,实际上该模块已经定义了一些常量,正确的用法,我们可以参考下面的例子:

 

[python] view plain copy
 
  1. >>> netifaces.ifaddresses('eth0')[netifaces.AF_INET]  
  2. [{'broadcast': '10.220.33.255', 'netmask': '255.255.255.0', 'addr': '10.220.33.101'}]  

 

网关和路由信息查询

为了方便使用,使用‘default’可以引用缺省网关配置,如果查询特定地址的网关信息,也非常容易,由于查询结果是字典形式表示,输入对应的接口地址类型,就可以查询指定的结果:

[python] view plain copy
 
  1. >>> netifaces.gateways()  
  2. {'default': {2: ('10.220.33.1', 'eth0')}, 2: [('10.220.33.1', 'eth0', True)]}  
  3. >>>  
  4. >>> netifaces.gateways()[netifaces.AF_INET]  
  5. [('10.220.33.1', 'eth0', True)]  

参考资料

posted @ 2017-09-19 16:11  “人生苦短”  阅读(11941)  评论(0编辑  收藏  举报