版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
[Linux命令]
[网络和系统篇]
目录
网络篇
1Ding遍大江南北
2DNS探秘之一--nslookuK初体验
3DNS探秘之二——DNS知识温故知新
4DNS探秘之三--一lookup输出解析
5DNS探秘之四一一DNS协议中的五元组
6DNS1采秘之五--nslookuK交口:模」弋
7DNS探秘之六——dig初体验
8DNS探秘之七一一dig选项走马观花
9iprout:e2系歹U之——--和r.etstat说再见
10iDroute2系列之二--篡权的ss
11iproute2系列之。--iproute2后浪推前浪
12iproute2系列之四--ip不只是地址
13iproute2系列之除了四还有六
14神探tcpdump第一招一一神探出场
15神探tcudumD第:招两个选项
16神探tcpdump第三招选项进阶
17神探tcpdumD第四招保存存回放
18书M冤tcpdump笫五招过:虑流■量
19神探tcpdump第六招过滤实战
20神探tcodumD第七招过滤高手
21神探tcpdump第八招一一输出解读
22神探tcpdiimp终结招七个秘籍
23nc,一只可爱的网猫
24ssh、cocy-id,帮你建立.信任
25rsync同步的的术
26其实你不懂wget的心之一--下载文件
27其实你不懂wget的心之二一一躲避封禁
28其实你不,懂WRCt的心之三一一下载目录
29其实你不,•11wget的心之四体贴的选项
进程和性能篇
1uptime给机器记考勤
2内存不决向free
3用好SWAP的空间
4Vmstat性能查看利器
5mpstat,i上你了解CPU的匚'
6top命令庖丁解牛之一一一入门
7top命令庖丁解牛之二一一列管理
8top命令庖丁解牛之三一一进程数据
9top命令庖「丁牛牛四——排序人法
10top命令庖丁解牛之五——CPU和内存
11iostat让1/0尽在掌握之中
12让Didof告诉我们进程ID
13sar访谈
14帮你找到幕后黑手一一Iscf应用篇
15帮你找到幕后黑手一一Isof悬疑篇
16帮你找到幕后黑手——Iscf进阶篇
17帮你找到幕后黑手一一(User学习篇
18DS命令看着简单,其实很难
19kill,这个杀手不太冷
20作业控制命令一览
21用trap捕捉那神秘的信号
22nohup,强大的防弹护甲
系统管理篇
1uname展示系统信息
2用户ID和用户组ID的一昵故事
3whoami不只是——部电影
4service服务最周到
5chkconfig掌控等级制度
6dmidecode看穿机器的底底
71smod列出内核模块
8最古老的容器技术chroot
9玩转关机和重启
网络篇
在网络篇中,我们将为大家带来29篇文章,所有内容都是围绕着网络技术和工具展开的,具体
如下:
•ping遍大江南北
•DNS探秘之一nslookup初体验
•DNS探秘之二——DNS知识温故知新
•DNS探秘之三nslookup输出解析
•DNS探秘之四--DNS协议中的五元组
•DNS探秘之五nslook叩交互模式
•DNS探秘之六一一dig初体验
•DNS探秘之七dig选项走马观花
•iproute2系列之一和netstat说再见
•iproute2系列之二篡权的ss
•iproute2系列之三iproute2后浪推前浪
•iproute2系列之四ip不只是地址
•iproute2系列之五除了四还有/'、
•神探tcpdump第一招神探出场
•神探tcpdump第二招两个选项
•神探tcpdump第三招选项进阶
•神探tcpdump第四招保存与回放
•神探tcpdump第五招一一过滤流量
•神探tcpdump第六招过滤实战
•神探tcpdump第七招过滤高手
•神探tcpdump第八招输出解读
•神探tcpdump终结招七个秘籍
•nc,一只可爱的网猫
•ssh-copy-id,帮你建立信任
•rsync同步的艺术
•其实你不懂wget的心之一一一下载文件
•其实你不懂wget的心之二一一躲避封禁
•其实你不懂wget的心之三一一下载目录
•其实你不懂wget的心之四体贴的选项
在这里,你不仅可以用nslookup和dig工具玩转DNS,还可以与神探tcpdump一起去网络流量
中探险,还可以了解到netstat被ss篡权的幕后故事,想想都激动!
让我们现在就开始网络篇的学习之旅吧。
1ping遍大江南北
ping不止是ping
接触过计算机网络的同学一定都知道ping命令吧,当计算机联网出现问题时,第一个进入脑海的
解决方法就是“ping-下网络呗"。ping是如此的常用,它绝对是你使用频率最高的•条网络命令
了。
在Windows系统中,我们更多的是简单地ping一下网站,来测试网络诈通性,就像这样:
ping
但作为更专业的Linuxer,知道这些还远远不够,今天我们就为大家更全面地介绍一下这位最熟
悉的陌生人ping命令。
指定ping的次数
受Windows使用习惯的影响’在Linux系统中需要ping的时候,你也许会这样:
[roc@roclinux$pingPING(06)56(84)bytesofdata.64
bytesfrom06:icmp_seq=lttl=49time=16.3ms64bytesfrom06:
icmp_seq=2ttl=49time=16.7ms64bytesfrom06:icmp_seq=3ttl=49time=15.9ms
64bytesfrom06:icmp_seq=4ttl=49time=19.1ms64bytesfrom06:
icmp_seq=5ttl=49time=18.1ms
当你满怀期待的等着命令自己结束,可等到花儿都谢了,命令还是在执行。这是怎么回事呢?原
来,Windows下的ping命令和Linux下的是有所不同的,Linux下的ping必须指定次数,不然
它会无限次地执行下去。
如何指定执行次数呢?很简单,只需使用-c选项来设定次数即可。比如,ping三次
网站的正确执行方法是:
[roc@roclinux〜]$ping-c3PING(06)56(84)bytesofdata.
64bytesfrom06:icmp_seq=lttl=49time=15.9ms64bytesfrom06:
icmp_seq=2ttl=49time=16.4ms64bytesfrom06:icmp_seq=3ttl=49time=15.7ms-
-pingstatistics-3packetstransmitted,3received,0%packetloss,time15673msrtt
min/avg/max/mdev=15.785/16.084/16.496/0.301ms
只重结果不重过程
不想看到ping命令那啰唆的过程,只相看到结果统计,因为只有结果才是最关键的。那有没有办
法满足大家这个小小的愿望呢?好消息!强大的ping命令说soeasy!只需简单地增加-q选项就行
To不信的话,试试下面的命令:
[roc@roclinux〜]$ping-q-c3PING(06)56(84)bytesofdata.
-pingstatistics—3packetstransmitted,3received,0%packetloss,time16794msrtt
min/avg/max/mdev=15.869/15.994/16.161/0.160ms
这样的ping绝对是模范员工,工作时埋头苦干,出报告时清晰准确。
这时,我突然发现了一个陌生的指标mdev,就在ping命令输出内容的最后一行,这个指标是用
来干什么的呢?
原来mdev是MeanDeviation的缩写,表示ICMP包的RTT偏离平均值的程度,主要用来衡量网
速的稳定性。mdev的值越大说明网速越不稳定。
另外,不同的操作系统的mdev的名字也有所不同,在mac下它叫作stddev,而在WindowsF
则根本没有这个统计指标。
指定ping的数据包的大小
默认情况下,ping命令是以64字节大小的数据包来测试M络联通性的,如需要改变默认数据包
的大小,则可以使用参数-s选项。比如你想使用65500字节的数据包来测试网络,命令可以这样
来写:
[roc@roclinux〜]$ping-s65500-c3PING(06)65500(65528)
bytesofdata.…pingstatistics-3packetstransmitted,0received,100%packetloss,
time11999m
在实际工作中,我们通常使佳-s选项来发现网络环境中有关MTU的问题。
指定ping的TTL
TTL,即生存时间,是指数据包被路由器丢弃之前允许通过的路由器跳数。
TTL是由发送主机来设置的,为了防止数据包在网络中无限循环,每个路由器在转发网络数据包
时,都要求将TTL的值减少1,直到TTL减为。的那一刻,也就是这个数据包生命终结的时刻。
对于ping命令发出的数据包,我们可以通过选项,来设定它在网络上的生命时长:
ping-t255
如果我们不使用选项来设置TTL,那么ping命令会采用TTL默认值。而不同的操作系统TTL
默认值也是不相同的。
下面给大家列举一些常用操作系统的默认值。
•Linux系统的TTL值为64或255
•WindowsNT/2000/XP系统的TTL值为128
•UNIX系统的TTL值为255
指定ping的时间间隔
ping命令的核心功能就是查看网络的联通性和网络的延迟。默认情况下,发送两个数据包之间的
间隔是1秒,如果我们嫌默认1秒发送一个ping包太慢,则可以使用-i选项来指定发送两个
ping包之间的时间间隔。不过需要注意的是,只有root用户才能设置低于0.2秒的时间间隔。下
面我们就以root用户实现0.1秒时间间隔的ping命令:
[root@roclinux〜]#ping-i0.1-c3PING(06)56(84)bytesof
data.64bytesfrom06:icmp_seq=lttl=49time=16.1ms64bytesfrom
06:icmp_seq=2ttl=49time=16.6ms64bytesfrom06:icmp_seq=3
ttl=49time=16.1ms-pingstatistics—3packetstransmitted,3received,0%packet
loss,time2119msrttmin/avg/max/mdev=16.134/16.331/16.699/0.260ms
爱如潮水般的ping
上文我们看到,ping命令在默认情况下使用1秒作为发送间隔,而使用-i选项可以显式地指定发
送间隔。如果我们希望ping命令以尽可能快的速度来发送数据包,则可以使用-f选项来实现爱如
潮水般的ping:
[root@roclinux〜|#ping-f-c100PING(06)56(84)bytesof
data.pingstatistics-100packetstransmitted,100received,0%packetloss,time
1473msrttmin/avg/max/mdev=15.444/16.269/21.434/1.082ms,pipe2,ipg/ewma
14.888/15.739ms
・f选项,即floodping,潮水模式的ping,听起来就无比威武,大有天降雄师的阵势。
这里有一个知识点要注意,Hoodping会采用无间隔的方式尽全力发送探测数据包,确保每秒钟
至少发送100个。我们把这种模式形象地称为“疯狂模式”,注意,这种方式只有root用户才可以
使用。
下面我们就使用floodping来测试一下网卡的丢包率:
[root@roclinux〜]#ping-f-c100009PING9(9)56(84)bytes
ofdata.—9pingstatistics--10000packetstransmitted,10000received,0%packet
loss,time144msrttmin/avg/max/mdev=0.003/0.004/0.043/0.003ms,ipg/ewma0.014/0.005
ms
“0%packetloss”表示丢包率为0,说明网卡工作非常正常,也没有任何网络拥塞发生。如果你想
查看•下你们公司内部的网络状况的话,只需将上述IP改成你们公司机器的IP地址就可以了。
篇尾小福利
最后,我们给出在网络实际使用过程中的一些RTT参考值,希望对你排查网络问题有一定的帮助,
如表1所示。
表1RTT参考值
场景RTT参考值
ping本机0.01ms
ping同机房机器0.1ms
ping同城机器Ims
ping不同城机器2Oins
北(南)方ping南(北)方机器5Oins
从国内ping国外机器200ms
提醒大家:网络很复杂,情况很多变,上述数据仅供参考。
好了,相信大家乂重新认识了一下老朋友一一ping,也学习了一些新玩法,希望能对大家的网络
问题排查有所帮助。
2DNS探秘之一nslookup初体验
DNSWnslookup的关系
DNS,BPDomainNameSystem,中文称之为“域名系统”,是计算机网络世界中非常重要的一个角
色,负责着整个互联网中“域名一IP地址”的管理和解析工作。
自从有了DNS,互联网就变得友好了许多,人们访问网站时不必再去记忆那些晦涩的【P地址,通
过一些非常易懂的字串就可以方便地指定目的网站。
我们平时都是通过来访问百度的,很少有人会记住它的【P地价吧!如果你对大
型网站的域名管理有所了解的话,你会知道IP地址解析还存在着就近解析和经常更换的问题,所
以,记忆1P地址并不切实际C
简单介绍了DNS之后,我们抓紧时间来为大家介绍一下今天的主角一一nslookupo
通过mannslookup,我们可以看到nslookup的官方解释是"queryInternetnameservers
interactively*^
而nslookup是nameserverlookup的缩写,顾名思义,nslookup就是"用来查询DNS的"。假如
你想知道对应的IP地址的话,那么用nslookup应该是最正确的方法了。
系统没有nslookup命令怎么办
如果你的Linux系统中没有nslookup命令,那么八成是你的系统中没有安装bind-utils软件包。
bind-utils软件包中包括了我们操作和管理DNS的一系列工具,比如host命令、dig命令、
nslookup命令等等。
安装bind-utils软件包,并非难事,在RHCE、CentOS或Fedora上,通过一条命令就可以搞定了:
yuminstallbind-utils
nslookup的两种模式
前面我们提到nslookup的官方解释是"queryInternetnameserversinteractively",这里的
interactively说明nslookup是具有交互功能的。
的确,nslookup共有两种工作模式,一种是“交互模式”,另一种则是“非交互模式”。
•在“交互模式”下,用户只需执行一次nslookup,就可以向域名服务器连续发起查询请求。
•在“非交互模式”下,用户发起的查询请求是一次性的,下次再想查询,就需要再执行一次
nslookup。
如何进入交互模式
nslookup的交互模式使我们可以连续发起DNS查询请求,而不必每次都运行nslookup命令。
进入交互模式的方法也很简单,只需输入nslookup命令,无须加任何参数,就可以直接进入交互
模式啦!
#进入至ij了nslookup的交互模式[roc@roclinux~]$nslookup>
看到最后的右尖括号“〉”了吧,这就是nslookup进入交互模式的重要标志。
需要注意的是,此时nslookup会连接到默认的域名服务器,也就是/etc/resolv.conf中所配置的
第一个DNS服务器地址。
如果我们想自己来指定一个DNS服务器地址,也是完全可以的,只需设置nslookup的第一个参
数为而第二个参数是要连接的DNS服务器IP地址即可。
假如我们想连接到谷歌的开放DNS,则可以这样来做:
#我们要连接到Google的开放DNS服务器[roc@roclinuxnslookup->
下面就在交互模式下实战一次,来查询域名的IP信息:
[roc@roclinux〜]$nslookup->Server:Address:
#53Non-authoritativeanswer:canonicalname=.Name:
Address:25Name:Address:21>
可以看到,Google的开放DNS服务器给我们返回了两个可用的IP地址,即25和
21o而且在这次查询请求之后,提示符仍然停留在“>”处,我们可以继续输入网站名
称进行下一次查询,这就是交互模式的特点。
如何进入非交互模式
非交百模式,其实并不需要进入,便用“进入”这个词,或许会有些误导之嫌.
如果你直接在nslookup命令后加上所要查询的域名,那么这就是非交互模式了。
比如,我们希望在非交互模式下查询域名对应的IP地址:
#杳询域名对应的IP地址[roc@roclinux〜]$nslookupServer:
Address:#53Non-authoritativeanswer:canonicalname=
.Name:Address:25Name:
Address:21[roc@roclinux〜]$
可以看到,在非交互模式下,我们进行完一次查询后,提示符会回到Shell提示符状态,下一次
再想查询DNS信息的话还需要执行nslookup命令,这就是非交互模式的特点。
好了,本文为大家介绍了nslookup的两种工作模式,并且演示了域名查询的方法,以及指定域名
服务器的方法。要想深入掌握nslookup,那就一定要对DNS协议有比较深入的理解,所以,在
接下来的一篇文章中,我们来学习DNS协议,对于大部分同学来说,可能算温故而知新啦。
3DNS探秘之二——DNS知识温故知新
在介绍完nslookup的模式之后,我们就要深入到其命令输出部分了。这些内容是和DNS协议的
知识紧密相关的,所以在讲解之前,我们需要把DNS的各类知识捉前讲解温习一下,确取大家可
以更好更顺畅地理解nslookup输出内容。
说到DNS协议,相信大家都知道它是一个应用层的协议,大部分场景下是用来管理域名和IP地
址的映射关系的。
DNS这套系统,采用了一种多级、分层次的组织方案,来实现对域名信息的管理。它的工作过程,
可以简述如下:
1.为了解析一个域名(如),应用程序会调用域名解析库函数,并将域名作为参
数传入其中。
2.然后,此解析库函数会提取本机所设置的上连DNS服务器地址,并向此地址发送一个域名解析
请求。
3.上连DNS服务器接到域名解析请求后,在本机杳找此域名,找到后将其对■应的IP地址返回给
解析库函数V
4.解析库函数接收到上连DNS服务器返回的信息后,将此信息返问给应用程序。
通过上面的4个步骤,应用程序就可以拿到一个域名对应的IP地址信息了。
而理想很丰满,现实很骨感,域名的解析过程并非总是那么顺利,有时候,我们会遇到“上连DNS
服务器”在它的本机并没有搜索到你要查询的域名信息的情况,这又如何是好呢?
DNS的递归行询是怎样的
为了更清楚地为大家介绍DNS查询的过程,也为了解答上一小节的那个遗留问题,我们来做一个
情景假设。
北邮(北京邮电大学)计算机学院的官方网站是,其中:
•cn:是国家域名。
•edu:是教育行业专属域名。
•bupt:是北京邮电大学的英文缩写,BPBeijingUniversityofPostandTelecommunicationa
•scs:是计算机学院的缩写,即SchoolofComputerScience。
假如小吴在家中希望访问北邮计算机学院的官方网站scs.b卬tedu.cn,于是浏览器会首先发起对
这个域名的DNS解析,我们来一起看看域名解析的过程,如图1所示。图中连线处的数字,.与下
面的步骤编号对应。
图1递归查询过程
第1步:为了解析这个域名(),浏览器会调用域名解析库函数,并将域名作为
参数传入其中。
第2步:然后,此解析库函数会提取本机所设置的上连DNS服务器地址,并向此地址发送•域名
解析请求。
第3步:上连DNS服务器接到域名解析请求后,在本机查找此域名,但是,遗憾的是,它并没有
找到对应的信息。
第4步:于是上连DNS服务器就会求助于根DNS服务器()。
第5步:此后,请求会逐级转发,顺序是cn的DNS服务器redu.cn的DNS服务器T
的DNS服务器。
第6步:由于一定是管理的资源记录的DNS服务器,于是,
的DNS服务器会将所查询域名对应的IP地址返回给上一级。
第7步:透个IP地价会按照逆序依次回传,顺序是的DNS服务器-cn的DNS服务器-
根DNS服务器。
第8步:最后根DNS服务器洛这个信息返回给上连DNS服务器。
第9步:上连DNS服务器收到结果后,首先会将这个结果缓存到本机,同时,将其回传给小吴家
中的浏览器。
这是一个典型的DNS递归查询(RecursiveQuery)过程,也确实比上一段落中描述的顺利过程复
杂了不少。
这里要注意一个细节,那就是上连DNS服务器在收到结果后,不仅会把结果返回给调用者,还会
自己缓存起来哦。
至于缓存起来之后的用处和可能带来的问题,我们先卖个关子,在深入讲解nslookup命令时会揭
晓答案。
除了递归还有什么
聪明的小伙伴们,或许已经隐隐感觉到了,既然我们明确指出了DNS递归查询过程,那就一定还
存在另一种查询过程。是的,你没猜错,DNS还为我们提供另一种可选方案,那就是迭代查询。
迭代查询的过程是这样的,我们再次回到小吴的浏览器面前,如图2所示。
图2迭代查询过程
第1步:为了解析这个域名(scs.bupt.edu.cn),浏览器仍然会调用域名解析库函数,并将域名
作为参数传入其中。
第2步:然后,此解析库函数会提取本机所设置的.上连DNS服务器地址,并向此地址发送一个域
名解析请求。
笫3步:上连DNS服务器接到域名解析请求后,在本机查找此域名,但是,遗憾的是,它并没有
找到对应的信息。
第4步:于是上连DNS服务器就会求助于根DNS服务器,注意迭代查询要开始啦。
第5步:根DNS服务器会将cn的DNS服务器的地址返回给上连DNS服务器,潜台词就是“虽然
我是根DNS服务器,但我也不是万能的,我其实也没法直接告诉你答案,但是呢,我可以给你引
荐一位高人,它一定可以告诉你进一步的线索,它就是cn*JDNS服务器,你去问问它吧,回
见!”
第6步:就这样,上连DNS服务器又依次去拜访了cn的DNS服务器-edu.cn的DNS服务器
->的DNS服务器。
第7步:由丁一定是知道的资源记录的,所以的DNS
服务器终于把最终答案告诉了上连DNS服务器。
第8步:上连DNS服务器收到结果后,首先会将这个结果缓存到本机,同时,将其回传给小吴家
中的浏览器。
这就是一个完整的DNS迭代查询过程,它和递归查询的最大区别在于:
•递归查询:好事办到底,每个环节都承担起了寻找答案的责任,都会负责去询问它的下一级
DNS服务器。
•迭代查询:给你指路,每个环节都是告诉你下一步怎么是,路还是要自己去走。
除了递归和迭代还有什么
那么,问题来了,除了递归查询、迭代查询,DNS查询还有什么新花样呢?真的还有,那就是“递
归与迭代相结合”的查询方法。
这种查询方法产生的背景是,根DNS服务器在全球仅有13台,每天都承载着全球数以亿计的查
询请求。为了尽量降低它们的工作负载,它们在收到查询请求后,会采用迭代查询的方法,将下
一级DNS服务器地址返回给请求方,而请求方再次去请求下一级DNS服务器时,则开始采用递
归查询的方法。这样,可以有效地降低根DNS服务器的负荷,提高全球的DNS查询效率,如图
3所示。相信大家可以自己看懂下图。
图3递归与迭代结合的查询过程
域名解析的缓存
还记得刚才我们在讲解递归查询时卖了•个关子么,有关“缓存”的关子,现在我们就来抿晓答案
咯。
如果你仔细看了nslookup的输出内容的话,就会发现里面有“Non-authoritativeanswer”的字样,
就像这样:
[roc@roclinux〜]$nslookupServer:Address:#53Non-
authoritativeanswer:canonicalname=.Name:
Address:21Name:Address:25
看到了吧,这个“Non-authoritativeanswer”就是和缓存知识密切相关的,大家只有了解了缓存的
原理和知识后,才能更好地理解"Non-authoritativeanswer'的含义。
现在我们就来说说有关DNS服务器的缓存的话题,这里面的学问还真的不少呢。
每一个DNS服务器都有一个高速缓存区,这里面存放着这台DNS服务器最近经手过的“域名一1P
地址”映射关系,以及获得这些映射关系的查询出处。正如我们上例中所描述的,上连DNS服务
器在获得了的IP地址后,就会把这个映射关系缓存在自己机器上,这样做的好处
就在于,下次再有人询问的IP信息的话,这台上连DNS服务器就不需要再发起
递归查询或迭代查询了,直接就可以从缓存中找到答案,并快速返回给询问者了。
理想很丰满,现实又是很骨感。我又要给大家泼冷水了。你有没有想过,事情其实并没有那么顺
利,因为机器经常会发生故障,网站也会偶尔迁移,所以域名对应的IP地址是会变化的。所以呢,
DNS服务器不能把这个信息缓存一辈子,需要给它设定一个期限,当然不可能是一万年,一般会
是小时级别的期限。一旦超过这个期限,DNS服务器就会不再信任自己缓存中的信息,而是重新
发起迭代查询或递归查询,去寻求最新的答案。
有了这样的机制,是不是我们的DNS查询就完美了呢,答案是N0!虽然我们将期限设置为了小
时级,但是仍然会存在不走运的“时间差”。假如一台DNS服务器在14:00刚刚缓存了
的解析数据,很不幸在14:05分,因为网站迁移修改了其对应的
IP地址,假如正好有一个用户通过这台DNS服务器来查询时,就会拿到过时的
IP地址了,是不是很坑人呢?
正是由于存在这种隐患和时间差,所以,如果DNS服务器是从自己缓存中提取解析数据返回给用
户的,那么就会很谨慎的在返回内容中给出"Non-authoritativeanswer”的字样,潜台词就是提示
用户:“朋友,我把答案告诉你了,但是,我可不保证它是最新的哦,因为这也是我前一阵听说的,
不是我现去查的。”
终于,我们揭开了"Non-authoritativeanswer”的神秘面纱。
不过,又会有好奇的同学提问了:“Non-authoritative在英文中是非权威的意思,这个词用得怪怪
的,有什么讲究么?”
授权和非授权
还真的是有讲究的。还记得刚才的迭代查询的例子么,例子中的DNS服务器会为你指一条明路,
即“虽然我不知道XXX的信息,但是,我可以给你引荐一位高人,他应该可以给你进一步的线
索。”是的!这位高人,就是我们下面要讲的“被授权的人”。
在DNS的世界里,没有人知道全部答案,但人们总能告诉你离正确答案更近的下一位高人。
我们来举个例子:
虽然的DNS服务器(我们称为A机)自己并不知道的IP地址,但是,
的DNS服务器知道负责域名解析的DNS服务器(我们称为B机)的地址,B
机就是那个离正确答案更近的高人。
所以,的DNS服务器(A机)就将的域名解析授权给了这台DNS服务器(B
机)。只有这台DNS服务器(B)所返回的有关的域名解析,才是授权的;否则,
就称为非授权的。
一般情况下,一台DNS服务器从自身缓存中提取结果并返回给询问者,这个结果就是非权威
(Non-authoritative)的。
好了,通过这样一篇文章我们把DNS的几个重要概念都复习了一遍,这为我们阅读后面的文章奠
定了良好的基础,相信大家阅读接下来的文章时会更加顺畅。接下来,我们就开始为大家解读
nslookap的输'I'内容。
4DNS探秘之三nslookup输出解析
我们仍然以的域名解析来作为样例,为大家详细解释nslookup的输出中都包含
了哪些重要内容:
[roc@roclinux〜]$nslookupv/Server:Address:#53Non-
authoritativeanswer:canonicalname=.Name:
Address:21Name:Address:25
可以看出,nslookup的输出包含了上下两部分。
•上半部分:DNS服务器信息。
•下半部分:域名解析信息。
DNS服务器信息中包含了两行内容,就是下面两行:
Server:Address:#53
第一行的Server,表示我们本次DNS解析所使用的DNS服务器名称,默认会采用系统生
/etc/resolv.conf文件中所配置的第一个DNS服务器。
第二行的Address,表示我们连接到的DNS服务器的具体IP地址和端口。这里#53就表示我们
访问的是DNS服务器的53号端口。53号端口也是DNSServer的默认服务端口。在亚马逊云
AWS中就有一个独立的产品叫作Route53,它是一个强调高可用和灵活伸缩的域名系统(DNS)
服务,名字中就直接使用了53这个数字。
介绍完了nslookup输出中的上半部分,我们再来看看重头戏,nslookup输出中的下半部分,也
就是"域名解析信息”:
Non-authoritativeanswer:canonicalname=.Name:
Address:21Name:Address:25
首先,映入眼帘的便是“Non-authoritativeanswer”,通过前面的学习我们知道,这表示返回的结
果是非权威的,可能会因为时间差的原因而不是最新的。
而下一行的信息,是我们之前没见过的,即:
canonicalname=.
canonicalname,就是我们常说的CNAME,也就是别名。所以我们可以看到,背
后的别名是。
再下面的内容,则表示真正的答案,也就是所对应的两个IP地址:
Name:Address:21Name:Address:
25
本文内容,相对来说比较紧凑精炼,和大家一起解读了nslookup的输出内容,将来你也可以为别
人讲解这些知识,享受别人投来的羡慕目光。是不是想想就觉得很美好,哈哈!
5DNS探秘之四——DNS协议中的五元组
传说中的五元组
一提到DNS,相信大家都会直观地认为DNS就是用来做域名和IP地址转换的,但其实并非如此,
准确地说,DNS是用来做域名和资源转换的,而1P地址只是资源中的一种而已。
当我们把一个域名查询的请求传递给DNS服务器后,DNS服务器所返回的是与该域名相关的资源
记录。那么资源是个什么东西呢?
在DNS的世界里,奥源是一个五元组,即:
{DomainName、TimeToLive.Class、Type、Value}
翻译成中文便是:
{域名、生存期限、类别、类型、值}
它们的含义如下。
•DomainName(域名):指我们要查询的那个域名。
•TimeToLive(生存期限):表示此域名在各DNS服务器缓存中应保存的时长。
•Class(类别):通常为IN,即Internet。另外还有CH(Chaos)和HS(Hesiod)两类,但目
前几乎已经被淘汰了。
•Type(类型):指出这条记录的类型,包括8种,即SOA、A、MX、NS、CNAME、PTR、
HINFO和TXT。
•Value(值):针对不同类型,会有不同的值°
为了让大家有一个直观的认识,我们截取了dig命令(后面的文章会讲到)的一小段输出作为例
子:
.7200INCNAME..7200INA00
因为我们已经介绍了五元组,所以这两行内容,相信大家已经大概看懂了:
•第1行:表示是的别名,其超时时限是7200秒。
•第2行:表示对应的IP地址是00,其超时时限同样为7200
秒。
DNS的八种类型
学习DNS五元组中的type知识,对于理解和使用nslookup命令是很重要的,在上一段落中,我
们知道type包含了8个可选类型,即:
•SOA:StartofAuthority,授权起始。
•A:IP地址。
•MX:邮件交换。
•NS:域名服务器。
•CNAME:别名,也叫规范名。
•PTR:指针,用于反向解析。
•HINFO:主机描述信息,包括CPU和OS等信息。
•TXT:其他一些文本信息。
为了让后面的内容学习起来更加顺畅,有必要为大家提前介绍一下这8种类型。
类型SOA
SOA,B|JStartOfAuthority,表示授权起始。在这里,我们可以获得针对一个域名的最基本的设
置信息,包括但不限于:
•Mail:管理员邮箱地址。
•Serial:版本序号,格式一般为年月日次,如2016031903则表示2016年03月19E的第03
个版本。
•RefreshSlave:表示Slave的DNS服务器多久向Master的DNS服务器要一次更新数据。
•Retry:在发起Refresh时,如果Slave连接不到Master:那么间隔多久进行一次连接尝试。
•Expire:在发起Refresh时,如果Slave始终无法连接到Master,那么多久后放弃尝试。
•Minimum:即TTL,表示外部DNS服务器如果要缓存本DNS服务器的授权数据,那么保存时
限是多久。
[roc@roclinux〜]$nslookup-type=soaServer:Address:#53Non-
authoritativeanswer:origin=mailaddr=serial=
2016031675refresh=10800retry=900expire=604800minimum=86400Authoritative
answerscanbefoundfrom:[roc@roclinux〜]$
类型A
A,表示从域名解析到IP地址。此处用来展示其对应的IP地址信息,俗称“A记录”。
[roc@roclinux~]$nslookup-:ype=aServer:Address:#53
Non-authoritativeanswer:Name:Address:114,255.40.66
类型MX
MX,是Mailexchanger的缩写,即邮件交换。此类型和邮箱服务器设置有关,用来表示当前域名
对应的邮箱服务器。
[roc@roclinux〜]$nslookup-:ype=mxServer:Address:#53Non-
authoritativeanswer:mailexchanger=5.mailexchanger
=5.mailexchanger=5.Authoritativeanswerscanbe
fuundfiuni:[ruc@ioclinux〜]$
当然,如果你的域名没有配置对应的邮箱服务器,则MX为空。
类型NS
NS,即NameServer,表示给定域名下所包含的DNS服务器信息。
[roc@roclinux〜]$nslookup-^pe=nsServer:Address:#53Non-
authoritativeanswer:nameserver=.nameserver=
.Authoritativeanswerscanbefoundfrom:[roc@roclinux〜]$
类型CNAME
CNAME,BPCanonicalName,也叫别名。比如就是的一个另ij名。
[roc@roclinux~]$nslookup-^pe=cnameServer:Address:#53
Non-authoritativeanswer:canonicalname=.Authoritative
answerscanbefoundfrom:[roc@roclinux〜]$
类型PTR
PTR,即指针,用来表示反解信息,即从IP地址杳询其对应域名的映射关系。
类型HINFO
HINFO,会包含CPU和OS等信息“
类型TXT
TXT,即文本信息,表示有关此域名的一些信息。
好了,DNS五元组的知识就讲到这里了,虽然有些枯燥,但是对于理解nslookup命令和接下来
的dig命令都是非常有帮助的。
6DNS探秘之五nslookup交互模式
直接查询域名A记录
在掌握了那么多的DNS知识之后,我们重新进入到nslook叩的交互模式中,一起再温习一遍各
种DNS查询的用法。
如果你直接输入域名(以举例),会有类似如下的输出:
$nslookup>Server:9〃上连的DNS服务器Address:9#53
〃上连的DNS服务器的IP地址与端口号Non-authoritativeanswer:〃非权威答案,即从上连
DNS服务器的本地缓存中读取的值canonicalname=.//说明
有另ij名叫Name://域名
Address:6//对应的IP地址之一Name:Address:7//
对应的IP地加之二
更改上连DNS地址
默认情况下,nslookup会连接到本机的默认上连DNS服务器去杳询域名的IP地址。
其实,我们可以使用server命令来指定上连DNS服务器的地址,来看下面的例子:
$nslookup>〃以默认的上连DNS服务器来查询Server:9Address:
9#53Non-authoritativeanswer:canonicalname=.
Name:Address:7Name:Address:
6>server〃更改了上连的DNS服务器地址为谷歌开放DNSDefaultserver:
Address:#53>〃以更改后的上连DNS服务器来查询Server:
Address:#53Non-authoritativeanswer:canonicalname=
.Name:Address:47〃看!IP地址变化/>说
明百度采用了智能DNS解析策略
从这个例子可以得到一个知识,那就是,针对同一个域名,两个不同的上连DNS服务器返回的IP
地址有可能是不同的。这可能是由于域名本身采用了智能DNS解析策略所造成的。
查看当前DNS的配置
列出nslookup工具的常用选项的当前设置值。
>setallDefaultserver:888.8〃当前的上连DNS服务器Address:#53〃当前的上连DNS
服务器的IP地址和端口Setoptions:novcnodebugnod2searchrecursetimeout=0retry=3port
=53querytype=Aclass=INsrchlist=
在上面所列出的配置项中,大家可以读懂大部分内容,包括timeout、querytype、class、retry、
port等,但有些配置项,比较高级,而在本系列文章中,不会继续介绍这些高级配置项,有兴趣
的读者可以通过计算机网络的专业书籍来学习和研究。
进入调试模式,查看更多交互信息
通过开启debug开关,可以让我们进入调试模式。在调试模式下,域名查询过程中完整的响应包
及其中的交互包,都会显示出来,方便大家追查问题和调试功能。
$nslookup、setdebug〃进入调试模式>Server:9Address:
9#53QUESTIONS:〃发出的查询请求,type=A,class=IN
ANSWERS:〃返【口I的信息、-〉canonicalname=.ttl=1192->
internetaddress=6ttl=262->internetaddress
=7ttl=262AUTHORITYRECORDS:ADDITIONALRECORDS:Non-
authoritativeanswer:canonicalname=.Name:
www.a.shifen.cuinAddress:6Name:www.a.bhifen.coniAddi7
注意:如果你使用setd2命令,则会开启高级调试模式,会输出更多nslookup内部工作的信息,
甚至包括许多函数调用信息。
指定查询中默认的域后缀
设置默认的域后缀,可以为我们的域名查询带来便捷。因为,对于所有尾部不包含的查询请求,
都会自动在尾部追加上我们所设置的域后缀。
$nslookup>setall〃首先显示上连DNS服务器信息以及所有的当前选项信息Defaultserver:
9Address:9#53Defaultserver:Address:#53Defaultserver:
8Address:8#53Setoptions:novcnodebugnod2searchrecurse
timeout=0retry=3port=53querytype=Aclass=INsrchlist=〃可以看到srchlist为空>set
domain=〃设置默认域为>setall〃再次查看选项信息Defaultserver:
9Address:61,139.2.69#53Defaultserver:Address:#53Defaultserver:
8Address:8#53Setoptions:novcnodebugnod2searchrecurse
timeout=0retry=3port=53querytype=Aclass=INsrchlist=〃口f以看至Usrchlist己
经被设置了后缀〉image〃直接查询imageServer:61.139269Address:
9#53Non-authoritativeanswer:canonicalname=.
〃可以看到已默认追加了.域后缀,变成了Name:
Address:220,181.111.131
在交互模式下设置type
通过setquerytype=[value],我们可以更改信息查询的类型。
默认情况下,nslookup是查询域名所对应的A记录,而当你想查询其对应的MX记录等旨息时,
就需要更改查询的类型了。
目前常用的type值如下:
A:查看主机的IPv4地址AAAA:查看主机的IPv6地址ANY:查看关于主机域的所有信息
CNAME:查找与别名对应的正式名字HINFO:查找主机的CPU与操作系统类型MINF0:查找邮
箱信息MX:查找邮件交换信息NS:查找主机域的域名服务器PTR:查找与给定1P地址兀配的主
机名RP:查找域负责人记录SOA:查找域内的SOA地址UINFO:查找用户信息
例如,针对MX类型的查询结果如下:
>settype=MX>〃查询MX信息Server:9Address:9#53Non-
authoritativeanswer:mailexchanger=20.mailexchanger=
20.mailexchanger=10.mail
exchanger=20.Authoritativeanswerscanbefoundfrom:>settype=A>
〃查询A记录Server:9Address:9#53Non-authoritativeanswer:Name:
Address:44Name:Address:220,181.111.85Name:
Address:6
好了,关于nslookup命令的用关知识我们就介绍到这里了。接下来的两篇文章,我们会为大家介
绍另一个好用的DNS杳询工具dig.
7DNS探秘之六——dig初体验
dig为自己代言
在平时查询DNS信息时,相信大家使用nslookup会更多一些,对dig深入了解的同学相对较少,
所以借这个机会,我们有必要花些时间给大家介绍一下dig命令的功能和用法。很多人不知道,
其实dig要比nslookup更加强大,dig是个有颜值的实力派。
对了,如果你还没有阅读过本系列的前几篇文章,那么我建议你还是先去读一下,那里面介绍了
不少有关DNS的基础知识,对于大家理解dig有很大帮助。
dig,其实是一个缩写,即DomainInformationGroper,它是一个DNS查询工具。
一些专业的DNS管理员在追查DNS问题时,都乐于使用dig命令,看中的便是dig设置灵活、
输出清晰、功能强大的特点。
最简单的dig用法
最简单的dig用法,当然就是直接执行dig命令啦:
[roc@roclinux~]$dig;«»DiG9.8.2rcl-RedHat-9.8.2-0.37.rcl.el6_7.4«»;;globaloptions:
+cmd;;Gotanswer:;;-»HEADER«-opcode:QUERY,status:NOERROR,id:33541;;flags:qrrdra;
QUERY:1,ANSWER:13,AUTHORITY:0,ADDITIONAL:0;;QUESTIONSECTION:;.INNS;;ANSWER
SECTION:.197458INNS..197458INNS..197458INNS
..197458INNSI...197458INNS..197458IN
NS..197458INNS..197458INNS..197458
INNS..197458INNS..197458INNS..
197458INNSa.root-servers.r.et..197458INNS.;;Querytime:43msec;;
SERVER:#53();;WHEN:TueMar111:20:312016;;MSGSIZErcvd:228
从上面的输出可以发现,当直接使用dig命令,不加任何参数和选项时,dig会向上连DNS服务
器查询(根域)的NS记录。
dig后加个点
刚才是直接输入dig,这次我们在后面加上一个点号表示杳询根域,看看结果和刚才相比有什
么区别:
[roc@roclinux〜]$dig.;«»DiG9.8.2rcl-RedHat-9.8.2-0.37.rcl.el6_7.4«».;;globaloptions:
+cmd;;Gotanswer:;;-»HEADER«-opcode:QUERY,status:NOERROR,id:20722;;flags:qrrdra;
QUERY:1,ANSWER:0,AUTHORITY:1,ADDITIONAL:0;;QUESTIONSECTION:INA;;AUTHORITY
SECTION:.9820INSOA..20160229011800900604800
86400;;Querytime:56msec;;SERVER;#53();;WHEN;TueMarl11:21:12
2016;;MSGSIZErcvd:92
可以看出,这次输出的是根域的A记录,这个例子中展示了13个根域之一的.
的五元组信息。
我们在前面的文章中介绍过“DNS的五元组知识”,大家可以回去温故知新一下。
我想用谷歌开放DNS来查询
在2009年,Google对外发布了一项全新的服务,即谷歌公共域名解析服务,英文称之为Google
PublicDNS,旨在为全球用户提供安全可靠的DNS解析服务。它的首选DNS服务器是8.S.8.8,
而备选DNS服务器则为8.8.4.4,都是非常好记的数字串。
卜面这个例子,就是使用谷歌开放DNS服务器来查询百度域名的A记录:
$dig@A〃命令格式为dig©dnsservernamequerytype;«»DiG
9.8.2rcl-RedHat-9.8.2-0.37.rcl.el6_7.4«»@A;(1serverfound);;global
options:+cmd;;Gotanswer:;;-»HEADER«-opcode:QUERY,status:NOERROR,id:48548;;flags:
qrrdra;QUERY:1,ANSWER:2,AUTHORITY:0,ADDITIONAL:0;;QUESTION
SECTION:;.INA;;ANSWERSECTION:.1185INCNAME
..192INA9;;Querytime:87msec;;SERVER:
8.8.88什53();;WHEN:TucMar111:26:032016;;MSGSIZErcvd:74
从上面这个例子,大家学习到了dig的基本的命令格式是:
$dig@dnsservernamequerytype
如果你没有设置@<3腌501*¥6=,那么dig会依次使用/etc/resolv.conf里的地址作为上连DNS服务
器。
而对于querytype,如果你阅读了《DNS探秘之四》和《DNS探秘之五》两篇文章,那么你应该
对querytype有所了解。如果忘记了,就赶快回去复习一下吧。
8DNS探秘之七一一dig选项走马观花
用选项实现批量查询
dig命令支持从一个文件里读取内容进行批量查询,这个功能非常体贴。我们来看一个实际的例
子:
#文件内容,共有两个域名需要查询[roc@roclinux〜]$catquerylist
#设置-f参数开始批量杳询,同时通过-t来指定查询类型[roc@roclinux〜|$dig-f
querylist-tA;«»DiG9.8.2rcl-RedHat-9.8.2-0.37.rcl.el6_7.4«»;;global
options:+cmd;;Gotanswer:;;-»HEADER«-opcode:QUERY,status:NOERROR,id:4725;;flags:
qrrdra;QUERY:1,ANSWER:3,AUTHORITY:0,ADDITIONAL:0;;QUESTION
SECTION:;.INA;;ANSWERSECTION:www.234INCNAME
..234INA112.80.24874.234INA
3;;Querytime:37msec;;SERVER:22355.5#53();;WHEN:TueMarl
15:24:382016;;MSGSIZErcvd:90;«»DiG9.8.2rcl-RedHat-9.8.2-0.37.rcl.el6_7.4«»
;;Gotanswer:;;-»HEADER«-opcode:QUERY,status:NOERROR,id:54774;;flags:
qrrdra;QUERY:1,ANSWER:4,AUTHORITY:0,ADDITIONAL:0;;QUESTION
SECTION:;.INA;;ANSWERSECTION:.28INCNAME.
.28INCNAME..28INA2
.28INA2;;Querytime:32msec;;SERVER:
#53();;WHEN:TueMar115:24:382016;;MSGSIZErcvd:102
用-t选项设置查询类型
我们可以使用-t选项设置要查询的资源类型,默认情况下是A。如果我们想查看域名的MX信息,
则方法如下:
#我们设置查询类型为M
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 融资租赁配套借款协议
- 汽车制造技术专利许可协议
- 食品稳定剂研发工程师考试试卷及答案
- 石漠化治理工程师考试试卷及答案
- 低温热水地板辐射采暖系统施工工艺
- 邮政校招就业协议书签订
- 竞业协议书不执行是否可以
- 签了保密协议书离职后泄密
- 路面恢复建设方案
- 外墙防水工程实施计划及报价构成
- 2026年重庆烟草招聘考试试题及答案
- 安徽省A10联盟2026届高三5月最后一卷历史试卷(含答案及解析)
- 2026年城管协管员业务知识考试题库及答案
- 2026年哈三中高三下学期三模语文试卷及答案
- 肠造口患者的心理支持与调适
- 河南省2026年普通高等学校对口招收中等职业学校毕业生考试机电与制造类基础课试卷
- 2026年普通动物学通关试题库及参考答案详解【达标题】
- 2025年广东省深圳市初二学业水平地生会考试题题库(答案+解析)
- 2026年度春季江西金德铅业股份有限公司校园招聘17人建设考试备考试题及答案解析
- 20kV及以下配电网工程预算定额(2022版)全5册excel版
- 2025福建龙岩国信物业有限公司招聘5人笔试历年难易错考点试卷带答案解析
评论
0/150
提交评论