欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

Linux系统中dig命令用法完全罗列

程序员文章站 2021-12-08 10:37:52
这篇文章主要介绍了Linux系统中dig命令用法完全罗列,dig命令用来处理域名解析相关操作,比nslookup命令要来得更加强大,需要的朋友可以参考下... 16-01-21...

语法
dig [@server] [-b address] [-c class] [-f filename] [-k filename] [ -n ][-p port#] [-t type] [-x addr] [-y name:key] [name] [type] [class] [queryopt...]
dig [-h]
dig [global-queryopt...] [query...]

描述
dig(域信息搜索器)命令是个用于询问 dns 域名服务器的灵活的工具。他执行 dns 搜索,显示从受请求的域名服务器返回的答复。多数 dns 管理员利用 dig 作为 dns 问题的故障诊断,因为他灵活性好、易用、输出清楚。虽然通常情况下 dig 使用命令行参数,但他也能够按批处理模式从文档读取搜索请求。不同于早期版本,dig 的 bind9 实现允许从命令行发出多个查询。除非被告知请求特定域名服务器,dig 将尝试 /etc/resolv.conf 中列举的任何服务器。当未指定任何命令行参数或选项时,dig 将对“.”(根)执行 ns 查询。

标志
-b address 配置所要询问地址的源 ip 地址。这必须是主机网络接口上的某一合法的地址。
-c class 缺省查询类(in for internet)由选项 -c 重设。class 能够是任何合法类,比如查询 hesiod 记录的 hs 类或查询 chaosnet 记录的 ch 类。
-f filename 使 dig 在批处理模式下运行,通过从文档 filename 读取一系列搜索请求加以处理。文档包含许多查询;每行一个。文档中的每一项都应该以和使用命令行接口对 dig 的查询相同的方法来组织。
-h 当使用选项 -h 时,显示一个简短的命令行参数和选项摘要。
-k filename 要签署由 dig 发送的 dns 查询连同对他们使用事务签名(tsig)的响应,用选项 -k 指定 tsig 密钥文档。
-n 缺省情况下,使用 ip6.arpa 域和 rfc2874 定义的二进制标号搜索 ipv6 地址。为了使用更早的、使用 ip6.int 域和 nibble 标签的 rfc1886 方法,指定选项 -n(nibble)。
-p port# 假如需要查询一个非标准的端口号,则使用选项 -p。port# 是 dig 将发送其查询的端口号,而不是标准的 dns 端口号 53。该选项可用于测试已在非标准端口号上配置成侦听查询的域名服务器。
-t type 配置查询类型为 type。能够是 bind9 支持的任意有效查询类型。缺省查询类型是 a,除非提供 -x 选项来指示一个逆向查询。通过指定 axfr 的 type 能够请求一个区域传输。当需要增量区域传输(ixfr)时,type 配置为 ixfr=n。增量区域传输将包含自从区域的 soa 记录中的序列号改为 n 之后对区域所做的更改。
-x addr 逆向查询(将地址映射到名称)能够通过 -x 选项加以简化。addr 是个以小数点为界的 ipv4 地址或冒号为界的 ipv6 地址。当使用这个选项时,无需提供 name、class 和 type 参数。dig 自动运行类似 11.12.13.10.in-addr.arpa 的域名查询,并分别配置查询类型和类为 ptr 和 in。
-y name:key 您能够通过命令行上的 -y 选项指定 tsig 密钥;name 是 tsig 密码的名称,key 是实际的密码。密码是 64 位加密字符串,通常由 dnssec-keygen(8)生成。当在多用户系统上使用选项 -y 时应该谨慎,因为密码在 ps(1)的输出或 shell 的历史文档中可能是可见的。当同时使用 dig 和 tscg 认证时,被查询的名称服务器需要知道密码和解码规则。在 bind 中,通过提供正确的密码和 named.conf 中的服务器声明实现。

参数
global-queryopt... 全局查询选项(请参阅多个查询)。
查询 查询选项(请参阅查询选项)。

查询选项
dig 提供查询选项号,他影响搜索方式和结果显示。一些在查询请求报头配置或复位标志位,一部分决定显示哪些回复信息,其他的确定超时和重试战略。每个查询选项 被带前缀(+)的关键字标识。一些关键字配置或复位一个选项。通常前缀是求反关键字含义的字符串 no。其他关键字分配各选项的值,比如超时时间间隔。他们的格式形如 +keyword=value。查询选项是:

+[no]tcp
    查询域名服务器时使用 [不使用] tcp。缺省行为是使用 udp,除非是 axfr 或 ixfr 请求,才使用 tcp 连接。
+[no]vc
    查询名称服务器时使用 [不使用] tcp。+[no]tcp 的备用语法提供了向下兼容。 vc 代表虚电路。
+[no]ignore
    忽略 udp 响应的中断,而不是用 tcp 重试。缺省情况运行 tcp 重试。
+domain=somename
    设定包含单个域 somename 的搜索列表,似乎被 /etc/resolv.conf 中的域伪指令指定,并且启用搜索列表处理,似乎给定了 +search 选项。
+[no]search
    使用 [不使用] 搜索列表或 resolv.conf 中的域伪指令(假如有的话)定义的搜索列表。缺省情况不使用搜索列表。
+[no]defname
    不建议看作 +[no]search 的同义词。
+[no]aaonly
    该选项不做任何事。他用来提供对配置成未实现解析器标志的 dig 的旧版本的兼容性。
+[no]adflag
    在查询中配置 [不配置] ad(真实数据)位。现在 ad 位只在响应中有标准含义,而查询中没有,但是出于完整性考虑在查询中这种性能能够配置。
+[no]cdflag
    在查询中配置 [不配置] cd(检查禁用)位。他请求服务器不运行响应信息的 dnssec 合法性。
+[no]recursive
    转换查询中的 rd(需要递归)位配置。在缺省情况下配置该位,也就是说 dig 正常情形下发送递归查询。当使用查询选项 +nssearch 或 +trace 时,递归自动禁用。
+[no]nssearch
    这个选项被配置时,dig 试图寻找包含待搜名称的网段的权威域名服务器,并显示网段中每台域名服务器的 soa 记录。
+[no]trace
    转换为待查询名称从根名称服务器开始的代理路径跟踪。缺省情况不使用跟踪。一旦启用跟踪,dig 使用迭代查询解析待查询名称。他将按照从根服务器的参照,显示来自每台使用解析查询的服务器的应答。
+[no]cmd
    设定在输出中显示指出 dig 版本及其所用的查询选项的初始注释。缺省情况下显示注释。
+[no]short
    提供简要答复。缺省值是以冗长格式显示答复信息。
+[no]identify
    当启用 +short 选项时,显示 [或不显示] 提供给答的 ip 地址和端口号。假如请求简短格式应答,缺省情况不显示提供给答的服务器的源地址和端口号。
+[no]comments
    转换输出中的注释行显示。缺省值是显示注释。
+[no]stats
    该查询选项设定显示统计信息:查询进行时,应答的大小等等。缺省显示查询统计信息。
+[no]qr
    显示 [不显示] 发送的查询请求。缺省不显示。
+[no]question
    当返回应答时,显示 [不显示] 查询请求的问题部分。缺省作为注释显示问题部分。
+[no]answer
    显示 [不显示] 应答的回答部分。缺省显示。
+[no]authority
    显示 [不显示] 应答的权限部分。缺省显示。
+[no]additional
    显示 [不显示] 应答的附加部分。缺省显示。
+[no]all
    配置或清除任何显示标志。
+time=t
    为查询配置超时时间为 t 秒。缺省是5秒。假如将 t 配置为小于1的数,则以1秒作为查询超时时间。
+tries=a
    配置向服务器发送 udp 查询请求的重试次数为 a,代替缺省的 3 次。假如把 a 小于或等于 0,则采用 1 为重试次数。
+ndots=d
    出于完全考虑,配置必须出现在名称 d 的点数。缺省值是使用在 /etc/resolv.conf 中的 ndots 语句定义的,或是 1,假如没有 ndots 语句的话。带更少点数的名称被解释为相对名称,并通过搜索列表中的域或文档 /etc/resolv.conf 中的域伪指令进行搜索。
+bufsize=b
    配置使用 edns0 的 udp 消息缓冲区大小为 b 字节。缓冲区的最大值和最小值分别为 65535 和 0。超出这个范围的值自动舍入到最近的有效值。
+[no]multiline
    以周详的多行格式显示类似 soa 的记录,并附带可读注释。缺省值是每单个行上显示一条记录,以便于电脑解析 dig 的输出。

多条查询
    dig 的 bind9 支持在命令行上指定多个查询(支持 -f 批处理文档选项的附加功能)。每条查询能够使用自己的标志位、选项和查询选项。
    在这种情况下,在上面描述的命令行语法中,每条查询自变量代表一个个别查询。每一条由任意标准选项和标志、待查询名称、可选查询类型和类连同任何适用于该查询的查询选项。
    也能够使用对任何查询均有效的查询选项全局集合。全局查询选项必须位于命令行上第一个名称、类、类型、选项、标志和查询选项的元组之前。任何全局查询选项(除了 +[no]cmd 选项)能够被下面的查询特别选项重设。例如:
    dig +qr www.isc.org any -x 127.0.0.1 isc.org ns +noqr显示 dig 如何从命令行出发进行三个查询:一个针对 www.isc.org的任意查询、一个 127.0.0.1 的逆向查询,连同一个 isc.org 的 ns 记录查询。应用了 +qr 的全局查询选项,以便 dig 显示进行每条查询的初始查询。最后那个查询有一个本地查询选项 +noqr,表示 dig 在搜索 isc.org 的 ns 记录时不显示初始查询。

例:
a,最简单的方法

复制代码
代码如下:

[root@rudder ~]# dig baidu.com

b,查找yahoo.com的a记录

复制代码
代码如下:

[root@rudder ~]# dig yahoo.com a +noall +answer

c,查找yahoo.com mx记录的列表

复制代码
代码如下:

[root@rudder ~]# dig yahoo.com mx +noall +answer

d,查找yahoo.com的权威dns

复制代码
代码如下:

[root@rudder ~]# dig yahoo.com ns +noall +answer

e,查询上面所有的记录

复制代码
代码如下:

[root@rudder ~]# dig yahoo.com any +noall +answer

f,在现在这种ipv4和ipv6混用的情况下,你也可以使用aaaa的选项查询主机的ipv6 aaaa记录

复制代码
代码如下:

[root@rudder ~]# dig www.baidu.com aaaa +short

g,快速回答时,+short

复制代码
代码如下:

[root@rudder ~]# dig www.baidu.com +short

h,+multiline选项获得冗长的多行模式人性化注释的dsn的soa记录,一般来说,用+multiline选项获得的信息可以显示很多,就像bind配置文件一样。

复制代码
代码如下:

[root@rudder ~]# dig +nocmd baidu.com any +multiline +noall +answer
;; truncated, retrying in tcp mode.
baidu.com. 7200 in soa dns.baidu.com. sa.baidu.com. (
2012111640 ; serial
300 ; refresh (5 minutes)
300 ; retry (5 minutes)
2592000 ; expire (4 weeks 2 days)
7200 ; minimum (2 hours)
)
baidu.com. 7200 in txt "v=spf1 ip4:220.181.50.0/24 ip4:220.181.18.241 ip4:61.208.132.13 ip4:220.181.27.29 ip4:202.108.22.171 ip4:220.181.5.0/24 ip4:123.125.66.0/24 ip4:61.135.168.0/24 ip4:115.239.212.0/24 ip4:58.217.202.0/24 ip4:61.135.162.0/23 ip4:63.217.157.86 a mx ptr ~all"
baidu.com. 7200 in mx 20 mx50.baidu.com.
baidu.com. 7200 in mx 10 mx.mailcdn.baidu.com.
baidu.com. 7200 in mx 20 mx1.baidu.com.
baidu.com. 7200 in mx 20 jpmx.baidu.com.
baidu.com. 600 in a 220.181.111.86
baidu.com. 600 in a 123.125.114.144
baidu.com. 600 in a 220.181.111.85
baidu.com. 21600 in ns ns2.baidu.com.
baidu.com. 21600 in ns ns4.baidu.com.
baidu.com. 21600 in ns ns3.baidu.com.
baidu.com. 21600 in ns dns.baidu.com.

i,使用-x 查询反向解析

复制代码
代码如下:

[root@rudder ~]# dig -x 220.181.111.86

j,查询一个不同的命名服务器

复制代码
代码如下:

[root@rudder ~]# dig @ns1.google.com www.google.com

k,跟踪dig的查询路径

复制代码
代码如下:

[root@rudder ~]# dig baidu.com +trace

l,获取soa记录

复制代码
代码如下:

[root@rudder ~]# dig baidu.com +nssearch

m,解释ttl数值

复制代码
代码如下:

[root@rudder ~]# dig +nocmd gmail.com mx +noall +answer

n,使用@指定服务器 使用-p指定非标准端口  使用-t来指定查询类型

复制代码
代码如下:

[root@rudder ~]# dig sohu.com @202.102.134.68 -p 53 -t mx