linux中跟踪路由命令,Linux命令:traceroute命令(路由跟踪)

简介: 【8月更文挑战第3天】traceroute是用来检测发出数据包的主机到目标主机之间所经过的网关数量的工具

traceroute是用来检测发出数据包的主机到目标主机之间所经过的网关数量的工具。traceroute的原理是试图以最小的TTL 存活时间 发出探测包来跟踪数据包到达目标主机所经过的网关 然后监听一个来自网关ICMP的应答。发送数据包的大小默认为38个字节。

原理 程序利用增加存活时间 TTL 来实现其功能。每当数据包(3个数据包包括源地址 目的地址和包发出的时间标签)经过一个路由器 其存活时间就会减1。当其存活时间是0时 主机便取消数据包 并传送一个ICMP Internet控制报文协议。它是TCP/IP协议族的一个子协议 用于在IP主机、路由器之间传递控制消息。控制消息是指网络通不通、主机是否可达、路由是否可用等网络本身的消息。这些控制消息虽然并不传输用户数据 但是对于用户数据的传递起着重要的作用。 TTL数据包给原数据包的发出者。

traceroute程序完整过程 首先它发送一份TTL字段为1的IP数据包给目的主机 处理这个数据包的第一个路由器将TTL值减1 然后丢弃该数据报 并给源主机发送一个ICMP报文 “超时”信息 这个报文包含了路由器的IP地址 这样就得到了第一个路由器的地址 然后traceroute发送一个TTL为2的数据报来得到第二个路由器的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 开启或关闭数据包的正确性检验。

4 实例

实例4.1 traceroute www.baidu.com


说明:

记录按序列号从1开始 每个纪录就是一跳 每跳表示一个网关 我们看到每行有三个时间 单位是 ms 其实就是-q的默认参数。探测数据包向每个网关发送三个数据包后 网关响应后返回的时间 如果您用 traceroute -q 4 www.58.com 表示向每个网关发送4个数据包。见下图

有时我们traceroute 一台主机时 会看到有一些行是以星号表示的。出现这样的情况 可能是防火墙封掉了ICMP的返回信息 所以我们得不到什么相关的数据包返回数据。

有时我们在某一网关处延时比较长 有可能是某台网关比较阻塞 也可能是物理设备本身的原因。当然如果某台DNS出现问题时 不能解析主机名、域名时 也会 有延时长的现象 您可以加-n 参数来避免DNS解析 以IP格式输出数据。

如果在局域网中的不同网段之间 我们可以通过traceroute 来排查问题所在 是主机的问题还是网关的问题。如果我们通过远程来访问某台服务器遇到问题时 我们用到traceroute 追踪数据包所经过的网关 提交IDC服务商 也有助于解决问题 但目前看来在国内解决这样的问题是比较困难的 就是我们发现问题所在 IDC服务商也不可能帮助我们解决。

实例4.2 跳数设置

命令 traceroute -m 10 www.baidu.com

结果

说明:通过结果可以看到存活数值 10 当存活数值 0时 主机便取消数据包

实例3 探测包使用的基本UDP端口设置6888

命令 traceroute -p 6888 www.baidu.com

结果

实例4 把对外发探测包的等待响应时间设置为3秒

命令 traceroute -w 3 www.baidu.com

结果

目录
相关文章
|
30天前
|
Ubuntu 搜索推荐 Linux
详解Ubuntu的strings与grep命令:Linux开发的实用工具。
这就是Ubuntu中的strings和grep命令,透明且强大。我希望你喜欢这个神奇的世界,并能在你的Linux开发旅程上,通过它们找到你的方向。记住,你的电脑是你的舞台,在上面你可以做任何你想做的事,只要你敢于尝试。
111 32
|
29天前
|
监控 Linux
Linux命令大全:echo与tail实现输出重定向。
这样,我们实现了使用echo和tail命令进行输出重定向的目的。在实际应用中,输出重定向技巧可节省时间,提高工作效率。希望本文内容对您了解和掌握Linux系统中echo与tail命令以及输出重定向的操作有所帮助。
99 27
|
25天前
|
消息中间件 Linux Kafka
linux命令使用消费kafka的生产者、消费者
linux命令使用消费kafka的生产者、消费者
110 16
|
1月前
|
Ubuntu Linux
"unzip"命令解析:Linux下如何处理压缩文件。
总的来说,`unzip`命令是Linux系统下一款实用而方便的ZIP格式文件处理工具。本文通过简明扼要的方式,详细介绍了在各类Linux发行版上安装 `unzip`的方法,以及如何使用 `unzip`命令进行解压、查看和测试ZIP文件。希望本文章能为用户带来实际帮助,提高日常操作的效率。
213 12
|
1月前
|
消息中间件 NoSQL Linux
Redis的基本介绍和安装方式(包括Linux和Windows版本),以及常用命令的演示
Redis(Remote Dictionary Server)是一个高性能的开源键值存储数据库。它支持字符串、列表、散列、集合等多种数据类型,具有持久化、发布/订阅等高级功能。由于其出色的性能和广泛的使用场景,Redis在应用程序中常作为高速缓存、消息队列等用途。
390 16
|
15天前
|
Linux
linux文件重命名命令
本指南介绍Linux文件重命名方法,包括单文件操作的`mv`命令和批量处理的`rename`命令。`mv`可简单更改文件名并保留扩展名,如`mv old_file.txt new_name.txt`;`rename`支持正则表达式,适用于复杂批量操作,如`rename 's/2023/2024/' *.log`。提供实用技巧如大小写转换、数字序列处理等,并提醒覆盖风险与版本差异,建议使用`-n`参数预览效果。
|
15天前
|
安全 Linux 网络安全
Linux wget 常用命令详解
wget 是一款强大的命令行下载工具,支持 HTTP/HTTPS/FTP 协议。本文详细介绍其基础用法、高效下载参数、高级应用场景及参数速查。内容涵盖断点续传(-c)、后台下载(-b)、限速下载(--limit-rate)、递归下载(-r)、整站镜像(-mk)等实用功能,同时提供文件管理、网络优化与安全下载配置方法,助您高效完成各类下载任务。
|
11月前
|
Linux
Linux部署04-ls命令的参数和选项,主体,参数,选项,ls / 查看根目录下的文件夹,-a的意思是列出全部选项 ls -a home全部文件,.代表着隐藏的文件夹,-l 选项,以列表竖向的形式展
Linux部署04-ls命令的参数和选项,主体,参数,选项,ls / 查看根目录下的文件夹,-a的意思是列出全部选项 ls -a home全部文件,.代表着隐藏的文件夹,-l 选项,以列表竖向的形式展
|
11月前
|
Linux
Linux部署 cd-pwd命令,cd 不写参数 就直接回到用户的HOME目录,pwd 查看当前的工作目录,pwd是常看当前目录的路径,无参数
Linux部署 cd-pwd命令,cd 不写参数 就直接回到用户的HOME目录,pwd 查看当前的工作目录,pwd是常看当前目录的路径,无参数
|
11月前
|
Linux
Linux02---命令基础 Linux命令基础, ls命令入门,ls命令参数和选项,命令行是一种以纯字符操作系统的方式,command命令本身,options命令的细节行为,parameter命令的
Linux02---命令基础 Linux命令基础, ls命令入门,ls命令参数和选项,命令行是一种以纯字符操作系统的方式,command命令本身,options命令的细节行为,parameter命令的