Linux学习之域名解析命令

 

(1) /etc/hosts :记录hostname对应的ip地址linux

 

  /etc/resolv.conf :设置DNS服务器的ip地址服务器

 

  /etc/host.conf :指定域名解析的顺序(是从本地的hosts文件解析仍是从DNS解析)tcp

(2) DNS的查询指令:host、nslookup、dig,host 语法:工具

host命令是经常使用的分析域名查询工具,能够用来测试域名系统工做是否正常。测试

host(选项)(参数)
spa

-a:显示详细的DNS信息; .net

-c<类型>:指定查询类型,默认值为“IN“; code

-C:查询指定主机的完整的SOA记录; server

-r:在查询域名时,不使用递归的查询方式; blog

-t<类型>:指定查询的域名信息类型;

-v:显示指令执行的详细信息;

-w:若是域名服务器没有给出应答信息,则老是等待,直到域名服务器给出应答;

-W<时间>:指定域名查询的最长时间,若是在指定时间内域名服务器没有给出应答信息,则退出指令;

-4:使用IPv4;

-6:使用IPv6.

1 [root@localhost ~]# host www.linuxde.net 
www.linuxde.net is an alias for host.1.linuxde.net. host.1.linuxde.net has address 100.42.212.8
[root@localhost ~]# host -a www.linuxde.net Trying "www.linuxde.net" ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 34671 ;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 0 ;; QUESTION SECTION: ;www.linuxde.net. IN ANY ;; ANSWER SECTION: www.linuxde.net. 463 IN CNAME host.1.linuxde.net. Received 54 bytes from 202.96.104.15#53 in 0 ms

(3) Nslookup 语法:

Nslookup [FQDN] [server]

Nslookup

参数说明:

能够直接在nslookup后加上待查询的主机名称或者ip,【server】无关紧要。

若是在nslookup后面没有加上任何主机名称或ip,那将进入nslookup的查询功能。在nslookup的查询功能当中,能够输入其余参数来进行特殊查询,例如:

Set type=any    :列出全部的信息

Set type=mx    :列出与mx相关的信息

(4) Dig 语法:

Dig [@server] [FQDN] [type]

参数说明:

@server :若是不想以/etc/resolv.conf来做为dns主机,则能够在此填入其余的ip

Type :预设是查询A记录,你能够在这里写入其余的记录,如:MX,NS等。

此功能亦可以使用[-t type]来处理。

下面是 dig 的一些比较经常使用的命令:

# dig 最基本的用法

1 dig @server sina.com.cn.

# 用 dig 查看 zone 数据传输

1 dig @server zx.xmgd.com. AXFR

# 用 dig 查看 zone 数据的增量传输

1 dig @server zx.xmgd.com. IXFR=N

# 用 dig 查看反向解析

1 dig -x 210.52.83.228 @server

# 查找一个域的受权 dns 服务器

1 dig xmgd.com. +nssearch

# 从根服务器开始追踪一个域名的解析过程

1 dig xmgd.com +trace

# 查看你使用的是哪一个 F root dns server

1 dig +norec @F.ROOT-SERVERS.NET HOSTNAME.BIND CHAOS TXT

    通常来讲linux下查询域名解析有两种选择,nslookup或者dig,而在使用上我以为dig更加方便顺手,若是是在debian下的话,只要装上dnsutils这个包就可使用dig命令了,最基本的使用方式就是:

1 dig www.baidu.com

 

    即查询域名的A记录,查询的dns服务器将采用系统配置的服务器,即/etc/resovle.conf 中的,若是要查询其余类型的记录,好比MX,CNAME,NS,PTR等,只需将类型加在命令后面便可

1 dig www.baidu.com mx
2 dig www.baidu.com ns

 

    此外,若是你是一个系统管理员,部署好了一台dns服务器以后想对它进行解析测试,就必需要显式指定待测试的dns服务器地址了,例如

1 dig @180.97.33.107 www.baidu.com a

 

    默认状况下dig将采用udp协议进行查询,若是要采用tcp方式,能够加上 +tcp参数

1 dig www.baidu.com a +tcp

 

    另一个重要的功能是+trace参数,使用这个参数以后将显示从根域逐级查询的过程

1 dig www.baidu.com a +trace

 

    好比,对本站域名www.linuxers.cn A记录的trace查询能够看到根域.,顶级域.cn,以及linuxers.cn的域名权威服务器的地址及其各自的返回结果,这样对于追踪dns解析中的问题有很大的帮助。

相关文章
相关标签/搜索