文章目录
1.dig是什么
dig,和nslookup作用有些类似,都是DNS查询工具
什么是CNAME:一个域名可以有两种类型的指向,如果一个 域名指向 称为一个 记录 (Record)的话,那么就有两种 记录类型 (Record Type),分别是:
A记录 :指向一个IP地址
CNAME :指向一个其他的域名
2.dig组成
输出结果大致分成4个部分,实际上可能还包括更多的内容,总共会有以下6个部分:
- Header : 包括软件版本,全局变量以及除消息头以外的其他部分的信息,比如上例中,显示有1个QUERY,2个ANSWER
- QUESTION SECTION : 请求参数信息,也就是你的输入
- ANSWER SECTION : 从DNS查询到的信息,也就是输出,显示 i.zhouliang.pro 是CNAME,指向
mydomain.lofter.com ,而后者是一个A记录,指向一个IP地址 - AUTHORITY SECTION : 包含DNS域名服务器的授权信息,上例中不包含这一部分,如果用这个命令就可以看到 dig
@ns1.redhat.com redhat.com ,这里的 @ 符号用于指定查询所使用的DNS服务器 - ADDITIONAL SECTION : 包含AUTHORITY SECTION中的域名服务器的IP地址,同样,上例中也不包含这一部分
- Stats section : 最下方的一部分,显示了查询时间等额外信息
如果你设置的dnsserver是一个域名,那么dig会首先通过默认的上连DNS服务器去查询对应的IP地址,然后再以设置的dnsserver为上连DNS服务器。
没有设置@dnsserver,那么dig就会依次使用**/etc/resolv.conf里的地址作为上连DNS服务器。
对querytype有所了解,你可以设置A/AAAA/PTR/MX/ANY**等值,默认是查询A记录。
3.dig实例
即查询域名的A记录,查询的dns服务器将采用系统配置的服务器,即/etc/resovle.conf
中的。
如果要查询其他类型的记录,比如MX,CNAME,NS,PTR等,只需将类型加在命令后面即可
此外,如果你是一个系统管理员,部署好了一台dns服务器之后想对它进行解析测试,就必须要显式指定待测试的dns服务器地址了,例如
默认情况下dig将采用udp协议进行查询,如果要采用tcp方式,可以加上 +tcp参数
另外一个重要的功能是+trace参数,使用这个参数之后将显示从根域逐级查询的过程
google-DNS来查baidu.com的A记录
.查看域名
第一行是CNAME,先将 i.zhouliang.pro 解析成 mydomain.lofter.com ,第二行是A记录,将 mydomain.lofter.com 解析成IP地址。这是一个完整的域名解析过程
2.查找域名的MX记录:
从输出可以看出,我用了QQ提供的域名邮箱服务
3.查找域名对应的CNAME:
4.根据IP地址反向查找域名
5.查询域名的解析DNS服务器地址