zoukankan      html  css  js  c++  java
  • 域名解析类型及dig,nslookup进行Dns解析过程查看

    本文为博主原创,未经允许不得转载:

      通常我们在windows系统下查看域名是不是可以正常访问,是通过cmd命令打开dos窗口,使用ping 命令来查看域名是不是可以正常访问,使用 ping 命令正常访问时,若域名能正常访问,则会返回一段数据包的统计信息, 如果接收的数据包与发送的包数量完全相同,则表示域名正常。示例如下:

    C:Userszenjian>ping baidu.com
    
    正在 Ping baidu.com [220.181.38.148] 具有 32 字节的数据
    来自 220.181.38.148 的回复: 字节=32 时间=23ms TTL=52
    来自 220.181.38.148 的回复: 字节=32 时间=24ms TTL=52
    来自 220.181.38.148 的回复: 字节=32 时间=24ms TTL=52
    来自 220.181.38.148 的回复: 字节=32 时间=27ms TTL=52
    
    220.181.38.148 的 Ping 统计信息:
        数据包: 已发送 = 4,已接收 = 4,丢失 = 0 (0% 丢失),
    往返行程的估计时间(以毫秒为单位):
        最短 = 23ms,最长 = 27ms,平均 = 24ms
    如果 ping 一个不存在的域名或非公网域名,则会 提示请求找不到主机,
    C:Userszenjian>ping ts.baidu.com
    Ping 请求找不到主机 ts.baidu.com。请检查该名称,然后重试。
    
    

    除了使用 ping 命令来查看域名是否正常访问,或查看域名的访问ip时,还可以使用 nslookup 来查看。nslookup是一种网络管理命令行工具,可用于查询DNS域名和IP地址,在网络故障的时候用来诊断网络问题。其最简单的使用方法与 ping 命令方法相同,直接使用 nslookup 域名即可。示例如下:

    C:Userszenjian>nslookup baidu.com
    服务器:  192.168.1.1
    Address:  192.168.1.1
    
    DNS request timed out.
        timeout was 2 seconds.
    名称:    baidu.com
    Addresses:  220.181.38.148
              39.156.69.79

    其中192.168.1.1是本机对应的 ip 段,这个命令在Linux环境上也可以使用,通过执行 nslookup 命令我们发现他会返回两个对应的 ip,这个ip就是baidu.com配置的访问的ip地址。通常一个域名会配置多个解析 ip,防止同时有大并发的请求到一台服务器,导致服务奔溃不可用,这种域名解析配置的方式称为 A 记录。

    域名解析的配置方式有很多种,主要由以下几种:

    (1)A记录,Address

    A记录用于描述域名到ip地址的映射关系。对同一个域名,可以有多条A记录。也就是说,一次DNS查找可以返回多个地址。

    (2)NS记录,Name Server

    NS记录是域名服务器记录,用于指定该域名由那个DNS服务器来进行解析。每个区域可以有多个域名服务器,因此可以有多条NS记录。

    (3)SOA记录,Start Of Authority

    SOA记录用于指定该区域的权威域名服务器。每个区域允许且只允许有一个SOA记录,它是资源记录的第一个条目。

    (4)CNAME记录

    CNAME记录用于描述别名与域名的对应关系,这种记录允许您将多个名字映射到同一台计算机。例如,有一台计算机名为host.mydomain.com(A记录)。它同时提供www和mail服务,为了便于用户访问服务,可以为该计算机设置两个别名(CNAME):www和mail。这两个别名的全称就是www.mydomain.com和mail.mydomain.com。实际上它们都指向host.mydomain.com。当域名服务器查找一个域名时,找到一条CNAME记录,它会用记录中的规范名来替换这个域名别名,然后再查这个规范名的A记录,从而找到与规范名对应的ip地址,这样,就实现了对请求查找域名的ip地址响应。

    (5)MX

    如果需要设置邮箱,让邮箱能够收到邮件,需要添加MX记录。

    (6)SOA

    SOA这种记录是所有区域性文件中的强制性记录。它必须是一个文件中的第一个记录。

    (7)TXT

    可以写任何东西,长度限制为255。绝大多数的TXT记录是用来做SPF记录(反垃圾邮件)。

    通过ping 命令是无法解析域名的解析类型,只能ping域名是否正常访问,获取域名的对应ip。若需要解析域名的类型可以使用nslookup。

    其语法域名的某一解析类型如下:

    --查询域名的mx/txt/ns解析记录
    nslookup -type=mx/txt/ns 52robot.org
    
    --还可以用 nslookup –qt=类型 目标域名。类型cname,txt,ns,mx
    nslookup -qt=cname/mx/txt/ns 52robot.org
    
    --查询域名的所有类型解析记录
    nslookup -type=any 52robot.org
    
    --从指定DNS服务器进行查询
    nslookup 52robot.org 223.5.5.5
     

    使用nslookup查询baidu.com的所有解析类型记录:

    C:Userszenjian>nslookup -type=any baidu.com
    服务器:  192.168.1.1
    Address:  192.168.1.1
    
    非权威应答:
    baidu.com       MX preference = 10, mail exchanger = mx.maillb.baidu.com
    baidu.com       MX preference = 15, mail exchanger = mx.n.shifen.com
    baidu.com       MX preference = 20, mail exchanger = mx1.baidu.com
    baidu.com       MX preference = 20, mail exchanger = jpmx.baidu.com
    baidu.com       MX preference = 20, mail exchanger = mx50.baidu.com
    baidu.com       nameserver = ns2.baidu.com
    baidu.com       nameserver = ns3.baidu.com
    baidu.com       nameserver = ns7.baidu.com
    baidu.com       nameserver = dns.baidu.com
    baidu.com       nameserver = ns4.baidu.com
     

    通过这个解析记录可以看到直接访问baidu.com可能会访问到以上mx,ns等的dns服务器上。使用nslookup命令已经可以帮我们查看域名的解析配置,在实际的应用配置中,现在更多的用的是 dig 命令进行查看配置解析,因为使用dig命令可以帮我们看到域名解析的服务链路,解析的线路更清楚,而且可以查看请求的状态和时长。

    dig 也是查看域名dns解析的工具,使用dig命令需要安装dig工具。在Linux环境只需要执行以下命令即可:

    yum install bind-utils

    dig命令的使用语法如下:

    dig(选项)(参数)

    其选项有以下:

    @<服务器地址>:指定进行域名解析的域名服务器;
    -b<ip地址>:当主机具有多个IP地址,指定使用本机的哪个IP地址向域名服务器发送域名查询请求;
    -f<文件名称>:指定dig以批处理的方式运行,指定的文件中保存着需要批处理查询的DNS任务信息;
    -P:指定域名服务器所使用端口号;
    -t<类型>:指定要查询的DNS数据类型;
    -x<IP地址>:执行逆向域名查询;
    -4:使用IPv4;
    -6:使用IPv6;
    -h:显示指令帮助信息。
     

    参数则有以下配置:

    主机:指定要查询域名主机;
    查询类型:指定DNS查询的类型;
    查询类:指定查询DNS的class;
    查询选项:指定查询选项。

    这里列举一下dig常用的请求命令:

    查询域名
    dig baidu.com
    
    查询mx记录
    dig -t mx baidu.com
    
    查询所有记录
    dig -t any baidu.com
    
    追踪所有解析,可以看到从客户端指定的dns服务器一步一步将dns请求转发到域名托管的dns服务器
    DNS的解析是递规解析,用trace参数,会显示完整的,无缓存,递规的查询,显示的是完整的trace记录。
    dig +trace baidu.com
    
    从指定DNS服务器进行查询
    dig @8.8.8.8 baidu.com
     

    另外常用的dns解析服务ip有两个,一个是8.8.8.8,另一个是114.114.114.114。从8.8.8.8 dns服务器解析追踪baidu.com的请求如下:

    [root@Test ~]# dig @8.8.8.8 baidu.com
    
    ; <<>> DiG 9.11.4-P2-RedHat-9.11.4-16.P2.el7_8.6 <<>> @8.8.8.8 baidu.com
    ; (1 server found)
    ;; global options: +cmd
    ;; Got answer:
    ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 43743
    ;; flags: qr rd ra; QUERY: 1, ANSWER: 2, AUTHORITY: 0, ADDITIONAL: 1
    
    ;; OPT PSEUDOSECTION:
    ; EDNS: version: 0, flags:; udp: 512
    ;; QUESTION SECTION:
    ;baidu.com.                     IN      A
    
    ;; ANSWER SECTION:
    baidu.com.              461     IN      A       39.156.69.79
    baidu.com.              461     IN      A       220.181.38.148
    
    ;; Query time: 51 msec
    ;; SERVER: 8.8.8.8#53(8.8.8.8)
    ;; WHEN: Sun Oct 25 14:35:09 CST 2020
    ;; MSG SIZE  rcvd: 70

    通过了解域名的解析类型,以及如何查看域名的解析类型记录,希望对域名能有更进一步的了解。并列举了nslookup和dig命令,在实际的应用时,可以根据不同的场景,正确快速的使用命令工具,帮助我们提供工作效率。

  • 相关阅读:
    MongoDB 基础
    类加载流程,类加载机制及自定义类加载器详解
    Object中有哪些方法及其作用
    Intellij IDEA 导入Maven项目
    用IDEA开发Spring程序
    深入浅出 Java 8 Lambda 表达式
    UUID.randomUUID()简单介绍
    json字符串转成 json对象 json对象转换成java对象
    字符串转 Boolean 的正确方式
    获取JSON中所有的KEY
  • 原文地址:https://www.cnblogs.com/zjdxr-up/p/14195053.html
Copyright © 2011-2022 走看看