dnspython模块提供了大量的DNS处理方法,最常用的方法是域名查询。dnspython提供了一个DNS解析器类——resolver,dnspython2.0版本中query方法已被作为过时的方法,现在dns.resolver使用它的resolve方法来实现域名的查询功能。resolve方法的定义如下:
def resolve(qname, rdtype=dns.rdatatype.A, rdclass=dns.rdataclass.IN,
tcp=False, source=None, raise_on_no_answer=True,
source_port=0, lifetime=None, search=None):
其中,qname参数为查询的域名。rdtype参数用来指定RR资源的类型,常用的有以下几种:
rdclass参数用于指定网络类型,可选的值有IN、CH与HS,其中IN为默认,使用最广泛。tcp参数用于指定查询是否启用TCP协议,默认为False(不启用)。source与source_port参数作为指定查询源地址和端口,默认值为查询设备IP地址和0。raise_on_no_answer参数用于指定当查询无应答时是否触发异常,默认为True。lifetime为查询超时时间,search参数为布尔值,在原来当访问的域名不能被DNS解析时,resolver会将该域名加上search指定的参数,重新请求DNS,直到被正确解析或试完search指定的列表为止。。
常见的DNS解析类型包括A,MX,MS,CNAME等。利用dnspython的dns.resolver.resolve方法可以简单实现这些DNS类型的查询,为后面要实现的功能提供数据来源,比如对一个使用DNS轮询业务的域名进行可用性监控,需要得到当前的解析结果。
A记录
#!/usr/bin/python3
import dns.resolver
domain = "www.baidu.com"
A = dns.resolver.resolve(domain,'A')
for i in A:
print(i)
=====output=====
183.232.231.172
183.232.231.174
MX记录
#!/usr/bin/python3
import dns.resolver
domain = "qq.com"
MX = dns.resolver.resolve(domain,'MX')
for i in MX:
print(i)
====output====
20 mx2.qq.com.
10 mx3.qq.com.
30 mx1.qq.com.
NS记录
#!/usr/bin/python3
import dns.resolver
domain = "qq.com"
NS = dns.resolver.resolve(domain,'NS')
for i in NS:
print(i)
====output====
ns3.qq.com.
ns2.qq.com.
ns1.qq.com.
ns4.qq.com.
CNAME记录
#!/usr/bin/python3
import dns.resolver
domain = "www.baidu.com"
CNAME = dns.resolver.resolve(domain,'CNAME')
for i in CNAME:
print(i)
====output====
www.a.shifen.com.
#!/usr/bin/python3
import dns.resolver
import httplib2
domain = 'www.baidu.com' #定义业务域名
iplist = [] #定义域名ip列表
def get_iplist(domain): #定义解析函数,解析成功IP将被追加到iplist
try:
A = dns.resolver.resolve(domain,'A') #解析a记录类型
except Exception as e:
print("dns resolver error:"+str(e))
return False
for i in A:
iplist.append(i) #追加到iplist
return True
def checkip(iplist):
for ip in iplist:
checkurl = str(ip)+":80"
getcontent = ""
httplib2.socket.setdefaulttimeout(5) #定义http连接超时时间(5秒)
conn = httplib2.HTTPConnectionWithTimeout(checkurl) #创建http连接对象
try:
conn.request("GET","/",headers={"HOST":domain}) #发起URL请求,添加host主机头
r = conn.getresponse()
getcontent = r.read(15) #获取URL页面前15个字符,以便做可用性校验
finally:
if getcontent==b"<!DOCTYPE html>":
print(str(ip)+"[OK]")
else:
print(str(ip)+"[ERROR]")
if __name__ == '__main__':
if get_iplist(domain) and len(iplist) > 0:
checkip(iplist)
else:
print('dns resolve error。')