当前位置: 首页 > 工具软件 > dnspython > 使用案例 >

python运维学习之dnspython模块

卞浩漫
2023-12-01

介绍

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资源的类型,常用的有以下几种:

  • A记录,将主机名装换成IP地址;
  • MX记录,邮件交换记录,定义邮件服务器的域名;
  • CNAME记录,指别名记录,实现域名间的映射;
  • NS记录,标记区域的域名服务器及授权子域;
  • PTR记录,反向解析,与A记录相反,将IP装换成主机名;
  • SOA记录,SOA标记,一个起始授权区的定义。

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轮询业务的域名进行可用性监控,需要得到当前的解析结果。

  1. 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
    
  2. 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.
    
  3. 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.
    
  4. 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.
    

DNS域名轮询业务监控

#!/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。')
 类似资料: