Python DNS处理模块dnspython(转载)

简介: DNS处理模块dnspython下载地址http://www.dnspython.org/kits/1.12.0/dnspython提供一个DNS解析器类——resolver,使用它的query方法来实现域名的查询功能。

DNS处理模块dnspython
下载地址
http://www.dnspython.org/kits/1.12.0/

dnspython提供一个DNS解析器类——resolver,使用它的query方法来实现域名的查询功能。
query(self,qname,rdtype=1,rdclass=1,tcp=False,source=None,raise_on_no_answer=True,source_prot=0)
其中,qname参数为查询的域名,rdtype参数用来指定RR资源的类型,常用的类型如下:
A记录:将主机名转换成IP地址
MX记录:邮件交换记录,定义邮件服务器的域名
CNAME记录:指别名记录,实现域名间的映射。
NS记录:标记区域的域名服务器及授权子域
PTR记录:反向解析,与A记录相反,将地址换成主机名
SOA记录:SOA标记,一个起始授权区的定义。

rdclass参数用于指定网络类型,可选的值为IN,CH,HS,IN为默认,使用最广泛。
tcp参数用于指定查询是否启用TCP协议,默认不启用。
source和source_prot指定查询源地址和端口,默认值为查询设备IP地址和0。
raise_on_no_answer指定当查询无应答时是否触发异常,默认为TRUE。

3.1 - 实现A记录查询方法
response.answer方法获取查询回应信息

[python] view plaincopy

  1. !/usr/bin/python

  2. * coding:utf-8 *

  3. Filename:dns1.py

  4. import dns.resolver

  5. def main():

  6. domain = raw_input('Enter an domain:')

  7. A = dns.resolver.query(domain,'A') #指定查询类型为A记录

  8. for i in A.response.answer:  #通过response.answer方法获取查询回应信息

  9. for j in i.items:

  10. print j

  11. if name=='main':

  12. main()

[root@lsn-linux python27]# python dns1.py
Enter an domain:www.baidu.com
www.a.shifen.com.
119.75.217.56
119.75.218.77

3.2 - 实现MX记录查询方法

[python] view plaincopy

  1. !/usr/bin/python

  2. * coding:utf-8 *

  3. Filename:dns2.py

  4. import dns.resolver

  5. def main():

  6. domain = raw_input('Enter an domain:')

  7. MX = dns.resolver.query(domain,'MX') #指定查询类型为MX记录

  8. for i in MX:

  9. print'MX preference=',i.preference,' mail exchanger=',i.exchange

  10. if name=='main':

  11. main()

[root@lsn-linux python]# python dns2.py
Enter an domain:139.com
MX preference= 5  mail exchanger= mx1.mail.139.com.
MX preference= 10  mail exchanger= mx2.mail.139.com.
MX preference= 20  mail exchanger= mx3.mail.139.com.

3.3 - 实现NS记录查询方法

[python] view plaincopy

  1. !/usr/bin/python

  2. * coding:utf-8 *

  3. Filename:dns3.py

  4. import dns.resolver

  5. def main():

  6. domain = raw_input('Enter an domain:')

  7. NS = dns.resolver.query(domain,'NS') #指定查询类型为NS记录

  8. for i in NS.response.answer:  #通过response.answer方法获取查询回应信息

  9. for j in i.items:

  10. print j

  11. if name=='main':

  12. main()

[root@lsn-linux python]# python dns3.py
Enter an domain:baidu.com
ns4.baidu.com.
ns2.baidu.com.
dns.baidu.com.
ns7.baidu.com.
ns3.baidu.com.

3.4 - 实现CNAME记录查询方法

[python] view plaincopy

  1. !/usr/bin/python

  2. * coding:utf-8 *

  3. Filename:dns4.py

  4. import dns.resolver

  5. def main():

  6. domain = raw_input('Enter an domain:')

  7. CNAME = dns.resolver.query(domain,'CNAME') #指定查询类型为CNAME记录

  8. for i in CNAME.response.answer:  #通过response.answer方法获取查询回应信息

  9. for j in i.items:

  10. print j

  11. if name=='main':

  12. main()

[root@lsn-linux python]# python dns4.py
Enter an domain:www.163.com
www.163.com.lxdns.com.
[root@lsn-linux python]# python dns4.py
Enter an domain:www.baidu.com
www.a.shifen.com

3.5 - DNS域名轮询业务监控
步骤:
a:实现域名的解析,获取域名所有A记录解析IP列表
b:对IP列表进行HTTP级别的探测

[python] view plaincopy

  1. !/usr/bin/python

  2. * coding:utf-8 *

  3. Filename:dns5.py

  4. import dns.resolver

  5. import os

  6. import httplib

  7. iplist=[]

  8. appdomain="www.baidu.com"

  9. def get_iplist(domain):

  10. try:

  11. A = dns.resolver.query(domain,'A')

  12. except Exception,e:

  13. print'dns resolver error:',str(e)

  14. return

  15. for i in A.response.answer:

  16. for j in i.items:

  17. iplist.append(j)

  18. return True

  19. def checkip(ip):

  20. checkurl=str(ip)+':80'

  21. getcontent=""

  22. httplib.socket.setdefaulttimeout(5)

  23. conn=httplib.HTTPConnection(checkurl)

  24. try:

  25. conn.request("GET","/",headers={"Host":appdomain})

  26. r=conn.getresponse()

  27. getcontent=r.read(15)

  28. finally:

  29. if getcontent=="":

  30. print ip," [OK]"

  31. else:

  32. print ip," [Error]"

  33. def main():

  34. if get_iplist(appdomain) and len(iplist)>0:

  35. for ip in iplist:

  36. checkip(ip)

  37. else:

目录
相关文章
|
4月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
556 7
|
4月前
|
监控 安全 程序员
Python日志模块配置:从print到logging的优雅升级指南
从 `print` 到 `logging` 是 Python 开发的必经之路。`print` 调试简单却难维护,日志混乱、无法分级、缺乏上下文;而 `logging` 支持级别控制、多输出、结构化记录,助力项目可维护性升级。本文详解痛点、优势、迁移方案与最佳实践,助你构建专业日志系统,让程序“有记忆”。
368 0
|
4月前
|
JSON 算法 API
Python中的json模块:从基础到进阶的实用指南
本文深入解析Python内置json模块的使用,涵盖序列化与反序列化核心函数、参数配置、中文处理、自定义对象转换及异常处理,并介绍性能优化与第三方库扩展,助你高效实现JSON数据交互。(238字)
478 4
|
4月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
444 0
|
4月前
|
XML JSON 数据处理
超越JSON:Python结构化数据处理模块全解析
本文深入解析Python中12个核心数据处理模块,涵盖csv、pandas、pickle、shelve、struct、configparser、xml、numpy、array、sqlite3和msgpack,覆盖表格处理、序列化、配置管理、科学计算等六大场景,结合真实案例与决策树,助你高效应对各类数据挑战。(238字)
353 0
|
5月前
|
安全 大数据 程序员
Python operator模块的methodcaller:一行代码搞定对象方法调用的黑科技
`operator.methodcaller`是Python中处理对象方法调用的高效工具,替代冗长Lambda,提升代码可读性与性能。适用于数据过滤、排序、转换等场景,支持参数传递与链式调用,是函数式编程的隐藏利器。
188 4
|
5月前
|
存储 数据库 开发者
Python SQLite模块:轻量级数据库的实战指南
本文深入讲解Python内置sqlite3模块的实战应用,涵盖数据库连接、CRUD操作、事务管理、性能优化及高级特性,结合完整案例,助你快速掌握SQLite在小型项目中的高效使用,是Python开发者必备的轻量级数据库指南。
468 0
|
5月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
456 102
|
5月前
|
数据采集 机器学习/深度学习 算法框架/工具
Python:现代编程的瑞士军刀
Python:现代编程的瑞士军刀
393 104
|
5月前
|
人工智能 自然语言处理 算法框架/工具
Python:现代编程的首选语言
Python:现代编程的首选语言
301 103