Linux追踪网络路由路径方法
时间:2026-03-29 14:03:40 194浏览 收藏
在Linux下使用traceroute追踪网络路径时,常遇到无响应、卡顿或满屏星号(*)的困惑,这往往并非命令故障,而是默认UDP探测被防火墙或中间设备静默丢弃所致;通过切换ICMP(-I)、TCP(-T)模式或改用无需root权限且更轻量的tracepath,可有效绕过限制,尤其适用于容器和云环境;理解“*”(超时/静默丢包)、“!H”(主机不可达)、“!N”(网络不可达)等返回码的真实含义,并关注延迟突增而非仅盯星号,才能精准定位真实瓶颈——真正关键的不是跑出跳数,而是读懂路径背后的网络策略与性能真相。

traceroute 命令为什么有时没反应或直接卡住
因为默认用 UDP 探测,目标主机或中间防火墙可能丢弃 UDP 包,导致超时、无响应或显示 *。这不是命令坏了,是网络策略在拦截。
- 改用 ICMP 模式更可靠:
traceroute -I example.com(-I表示 ICMP) - 某些系统(如 CentOS/RHEL 8+)默认不带
traceroute,需先装:yum install traceroute或apt install inetutils-traceroute - 普通用户无法发 ICMP 包?加
sudo,但注意:部分系统限制非 root 用户用-I
Linux 下 traceroute 和 tracepath 有什么区别
tracepath 是更轻量的替代方案,无需 root 权限,且自动探测 MTU,但不支持自定义端口或协议;traceroute 功能全、可调参数多,但依赖权限和安装包。
tracepath example.com:开箱即用,适合快速看跳数和延迟,尤其在容器或最小化系统里traceroute -T -p 443 example.com:用 TCP 发包(-T),指定端口(-p),绕过 UDP 封锁,适合诊断 HTTPS 服务连通性traceroute的-q(每跳探测次数)、-w(超时秒数)会影响输出速度和准确性,内网调试建议设小点,比如-q 1 -w 2
看到 * * * 或 “!H” “!N” 这些返回码代表什么
不是故障,是中间设备返回的 ICMP 错误类型:!H = 主机不可达(Host unreachable),!N = 网络不可达(Network unreachable),* = 超时或静默丢包(最常见)。
- 连续几跳都是
*,大概率是某段路径禁用了 ICMP/UDP 回复,不代表断连,只是“看不见” - 某跳突然从
*变成!X,说明探测包至少抵达了那台设备,它主动拒绝了——这是有用信息 - 别只盯着星号,关注延迟突增的位置:从 5ms 跳到 200ms,比一串
*更值得查
traceroute 在容器或云主机里结果不准怎么办
容器共享宿主机网络栈,但常被 iptables/nftables 规则截断探测包;云厂商(如 AWS、阿里云)的虚拟网络设备也普遍不响应 traceroute,导致路径“断在半路”。
- 容器内优先用
tracepath,它走的是内核路径发现机制,不依赖外部响应 - 云主机上,
traceroute -n(禁用 DNS 解析)能避免因反向解析慢而误判超时 - 若需真实路径,得在跳数变化点两端分别 traceroute:比如从客户端到 LB 是 5 跳,从 LB 后端 ECS 到目标又是 3 跳——单次 traceroute 永远看不到全貌
事情说清了就结束。真正难的不是跑出那串跳数,而是判断哪一跳的 * 是策略屏蔽、哪一跳的延迟突增是真实瓶颈、以及什么时候该换工具而不是硬等。
到这里,我们也就讲完了《Linux追踪网络路由路径方法》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
287 收藏
-
175 收藏
-
399 收藏
-
141 收藏
-
268 收藏
-
329 收藏
-
325 收藏
-
110 收藏
-
402 收藏
-
443 收藏
-
388 收藏
-
116 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习