简单来说就是查看 从当前主机到目的主机之间经过了多少个路由器、路由IP是什么?
参数命令 可以 在命令板输入 tracert /?
查看:
tracert命令对于了解包括解决大型网络非常使用,它能摸索所处大型局域网里网络拓扑架构,除了一些禁止ping的路由器(一般出口路由器或者防火墙上)。
tracert命令功能同Ping类似,但它所获得的信息要比Ping命令详细得多,它把数据包所走的全部路径、节点的IP以及花费的时间都显示出来。该命令比较适用于大型网络。
使用说明
tracert 先发送 TTL 为 1 的回应数据包,当数据包上的 TTL在路由器收到后TTL自动减1 ,一旦某个服务器将TTL减1后,等于了0,路由器应该将“ICMP Time Exceeded”的消息发回源计算机,源计算机就根据收到的信息判断达到的路由器和所用时间。下次再次发送数据包时,将TTL递增 1,继续上述测试,直到目标响应或 TTL 达到最大值,从而确定路由。通过检查中间路由器发回的“ICMP 已超时”的消息确定路由。某些路由器不经询问直接丢弃 TTL过期的数据包,这在 Tracert 实用程序中看不到,我们会显示请求超时的请求信息。
命令格式:tracert hostname
如:查看 baidu.com的路由可以直接 tracert hostname
即可!!!!
traceroute在linux下使用
==================================================================================
功能说明
敲黑板!!!
注意: tracert 是在windows 上使用的,linux下命令是 traceroute !!!
简单来说就是查看 从当前主机到目的主机之间经过了多少个路由器、路由IP是什么?
Traceroute的工作原理:
Traceroute程序的设计是利用ICMP及IP header的TTL(Time To Live)栏位(field)。首先,traceroute送出一个TTL是1的IP datagram(其实,每次送出的为3个40字节的包,包括源地址,目的地址和包发出的时间标签)到目的地,当路径上的第一个路由器(router)收到这个datagram时,它将TTL减1。此时,TTL变为0了,所以该路由器会将此datagram丢掉,并送回一个「ICMP time exceeded」消息(包括发IP包的源地址,IP包的所有内容及路由器的IP地址),traceroute 收到这个消息后,便知道这个路由器存在于这个路径上,接着traceroute 再送出另一个TTL是2 的datagram,发现第2 个路由器… traceroute 每次将送出的datagram的TTL 加1来发现另一个路由器,这个重复的动作一直持续到某个datagram 抵达目的地。当datagram到达目的地后,该主机并不会送回ICMP time exceeded消息,因为它已是目的地了,那么traceroute如何得知目的地到达了呢?
Traceroute在送出UDP datagrams到目的地时,它所选择送达的port number 是一个一般应用程序都不会用的号码(30000 以上),所以当此UDP datagram 到达目的地后该主机会送回一个「ICMP port unreachable」的消息,而当traceroute 收到这个消息时,便知道目的地已经到达了。所以traceroute 在Server端也是没有所谓的Daemon 程式。
Traceroute提取发 ICMP TTL到期消息设备的IP地址并作域名解析。每次 ,Traceroute都打印出一系列数据,包括所经过的路由设备的域名及 IP地址,三个包每次来回所花时间。
参数说明
1.命令格式:
traceroute[参数][主机]
2.命令功能:
traceroute指令让你追踪网络数据包的路由途径,预设数据包大小是40Bytes,用户可另行设置。
具体参数格式:traceroute [-dFlnrvx][-f<存活数值>][-g<网关>…][-i<网络界面>][-m<存活数值>][-p<通信端口>][-s<来源地址>][-t<服务类型>][-w<超时秒数>][主机名称或IP地址][数据包大小]
3.命令参数:
-d 使用Socket层级的排错功能。
-f 设置第一个检测数据包的存活数值TTL的大小。
-F 设置勿离断位。
-g 设置来源路由网关,最多可设置8个。
-i 使用指定的网络界面送出数据包。
-I 使用ICMP回应取代UDP资料信息。
-m 设置检测数据包的最大存活数值TTL的大小。
-n 直接使用IP地址而非主机名称。
-p 设置UDP传输协议的通信端口。
-r 忽略普通的Routing Table,直接将数据包送到远端主机上。
-s 设置本地主机送出数据包的IP地址。
-t 设置检测数据包的TOS数值。
-v 详细显示指令的执行过程。
-w 设置等待远端主机回报的时间。
-x 开启或关闭数据包的正确性检验。
使用说明
实例1:traceroute 用法简单、最常用的用法
命令:traceroute www.baidu.com
[root@control ~]$traceroute baidu.com
traceroute to baidu.com (220.181.38.148), 30 hops max, 60 byte packets
1 10.233.3.252 (10.233.3.252) 2.063 ms 1.993 ms 5.028 ms
2 10.233.83.249 (10.233.83.249) 8.017 ms 8.325 ms 8.696 ms
3 10.237.232.6 (10.237.232.6) 0.582 ms 0.519 ms 0.453 ms
4 10.237.232.89 (10.237.232.89) 0.626 ms 0.576 ms 0.548 ms
5 211.139.72.77 (211.139.72.77) 7.556 ms 7.953 ms 8.337 ms
6 * * *
7 221.176.20.201 (221.176.20.201) 1.685 ms 221.183.38.205 (221.183.38.205) 1.642 ms 221.176.20.201 (221.176.20.201) 1.484 ms
8 221.176.26.41 (221.176.26.41) 85.199 ms 85.054 ms 221.183.36.13 (221.183.36.13) 65.519 ms
9 * * *
10 * 221.183.65.226 (221.183.65.226) 76.016 ms *
11 202.97.88.225 (202.97.88.225) 75.868 ms 202.97.57.49 (202.97.57.49) 78.598 ms 202.97.88.225 (202.97.88.225) 79.354 ms
12 180.149.159.10 (180.149.159.10) 70.698 ms 180.149.128.50 (180.149.128.50) 85.678 ms *
13 220.181.16.62 (220.181.16.62) 74.389 ms * *
14 * * *
15 * * *
16 * * *
17 * * *
18 * * *
19 * * *
20 * * *
21 * * *
22 * * *
23 * * *
24 * * *
25 * * *
26 * * *
27 * * *
28 * * *
29 * * *
30 * * *
[root@control ~]$
说明:
记录按序列号从1开始,每个纪录就是一跳 ,每跳表示一个网关,我们看到每行有三个时间,单位是 ms,其实就是-q的默认参数。探测数据包向每个网关发送三个数据包后,网关响应后返回的时间;如果您用 traceroute -q 4 www.58.com ,表示向每个网关发送4个数据包。
有时我们traceroute 一台主机时,会看到有一些行是以星号表示的。出现这样的情况,可能是防火墙封掉了ICMP的返回信息,所以我们得不到什么相关的数据包返回数据。
有时我们在某一网关处延时比较长,有可能是某台网关比较阻塞,也可能是物理设备本身的原因。当然如果某台DNS出现问题时,不能解析主机名、域名时,也会 有延时长的现象;您可以加-n 参数来避免DNS解析,以IP格式输出数据。
如果在局域网中的不同网段之间,我们可以通过traceroute 来排查问题所在,是主机的问题还是网关的问题。如果我们通过远程来访问某台服务器遇到问题时,我们用到traceroute 追踪数据包所经过的网关,提交IDC服务商,也有助于解决问题;但目前看来在国内解决这样的问题是比较困难的,就是我们发现问题所在,IDC服务商也不可能帮助我们解决。
实例2:跳数设置
命令:traceroute -m 10 www.baidu.com
输出:
aceroute to www.baidu.com (61.135.169.121), 10 hops max, 60 byte packets
1 10.233.3.252 (10.233.3.252) 1.365 ms 1.239 ms 2.225 ms
2 localhost (10.233.83.249) 4.774 ms 5.128 ms 5.513 ms
3 bogon (10.237.232.6) 0.604 ms 0.579 ms 0.489 ms
4 localhost (10.237.232.89) 0.573 ms 0.537 ms 0.521 ms
5 211.139.72.77 (211.139.72.77) 6.062 ms 6.332 ms 6.725 ms
6 211.139.74.201 (211.139.74.201) 1.565 ms 1.851 ms 1.767 ms
7 221.176.20.201 (221.176.20.201) 1.586 ms 221.183.38.205 (221.183.38.205) 1.500 ms 1.422 ms
8 221.176.26.41 (221.176.26.41) 63.683 ms * *
9 * * *
10 219.158.39.61 (219.158.39.61) 69.765 ms 219.158.34.229 (219.158.34.229) 76.791 ms 219.158.34.21 (219.158.34.21) 69.572 ms
实例3:显示IP地址,不查主机名
命令:traceroute -n www.baidu.com
输出:
[root@control ~]$ traceroute -n www.baidu.com
traceroute to www.baidu.com (61.135.169.121), 30 hops max, 60 byte packets
1 10.233.3.252 1.410 ms 1.274 ms 1.223 ms
2 10.233.83.249 17.704 ms 18.045 ms 18.354 ms
3 10.237.232.6 0.593 ms 0.558 ms 0.489 ms
4 10.237.232.89 0.571 ms 0.535 ms 0.543 ms
5 211.139.72.77 6.208 ms 6.428 ms 6.742 ms
6 * * *
7 221.183.38.205 1.374 ms 1.357 ms 1.315 ms
8 221.176.26.41 62.630 ms 62.459 ms *
9 * * *
10 219.158.39.61 70.210 ms 219.158.34.17 71.986 ms *
11 219.158.3.65 66.406 ms 63.550 ms 66.523 ms
12 125.33.186.86 74.274 ms 123.126.0.26 67.423 ms *
13 61.51.115.102 72.728 ms 124.65.58.62 66.723 ms 66.779 ms
14 202.106.43.30 74.569 ms 123.125.248.94 74.390 ms *
15 * * *
16 * * *
17 * * *
18 * * *
19 * * *
20 * * *
21 * * *
22 * * *
23 * * *
24 * * *
25 * * *
26 * * *
27 * * *
28 * * *
29 * * *
30 * * *
[root@control ~]$
实例4:探测包使用的基本UDP端口设置6888
命令:traceroute -p 6888 www.baidu.com
输出:
[root@control ~]$traceroute -p 6888 www.baidu.com
traceroute to www.baidu.com (39.156.66.18), 30 hops max, 60 byte packets
1 bogon (10.233.3.252) 1.393 ms 1.143 ms 1.188 ms
2 localhost (10.233.83.249) 4.806 ms 5.121 ms 5.498 ms
3 localhost (10.237.232.6) 0.538 ms 0.582 ms 0.452 ms
4 bogon (10.237.232.89) 0.637 ms 0.580 ms 0.543 ms
5 211.139.72.77 (211.139.72.77) 7.063 ms 7.377 ms 7.751 ms
6 211.139.74.201 (211.139.74.201) 1.363 ms 1.364 ms 1.396 ms
7 * * *
8 221.183.56.93 (221.183.56.93) 56.348 ms 53.990 ms 53.944 ms
9 * * *
10 * 39.156.27.5 (39.156.27.5) 57.329 ms 57.935 ms
11 39.156.27.1 (39.156.27.1) 55.070 ms 39.156.67.13 (39.156.67.13) 57.057 ms 39.156.27.1 (39.156.27.1) 54.963 ms
12 * 39.156.67.25 (39.156.67.25) 59.546 ms 39.156.67.41 (39.156.67.41) 54.900 ms
13 * * *
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Linux运维工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Linux运维知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip1024b (备注Linux运维获取)
最后的话
最近很多小伙伴找我要Linux学习资料,于是我翻箱倒柜,整理了一些优质资源,涵盖视频、电子书、PPT等共享给大家!
资料预览
给大家整理的视频资料:
给大家整理的电子书资料:
如果本文对你有帮助,欢迎点赞、收藏、转发给朋友,让我有持续创作的动力!
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
3044307805)]
最后的话
最近很多小伙伴找我要Linux学习资料,于是我翻箱倒柜,整理了一些优质资源,涵盖视频、电子书、PPT等共享给大家!
资料预览
给大家整理的视频资料:
[外链图片转存中…(img-5ENkutDn-1713044307805)]
给大家整理的电子书资料:
[外链图片转存中…(img-g13NyWuu-1713044307805)]
如果本文对你有帮助,欢迎点赞、收藏、转发给朋友,让我有持续创作的动力!
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-mfzoGllH-1713044307806)]