如何理解 IP 数据报中的 TTL?


目录


前言

面试灵魂一问:说说对 IP 数据报中 TTL 的理解?我们都知道,IP 数据报由首部和数据两部分组成,首部又分为两部分:固定部分和可变部分,共占 20 字节,而即将讨论的 TTL 就位于首部的固定部分,这个 TTL 指的就是数据报在网络环境中的"生存时间"

理解

TTL 是"生存时间"的英文缩写(Time To Live),共占 8 位,由发出数据报的源点进行设置,目的是为了防止无法交付的数据报无限制存在于互联网中,从而耗费网络资源。TTL 最初的设计是以"秒"为单位,数据报每进过一个路由器就把 TTL 减去数据报在路由器所消耗的时间。当 TTL 值减为 0 时,就丢弃这个数据报。

而现在的计算机网络中 TTL 的单位已经不再是"秒",而是"跳数",其含义就是数据报在互联网中可以经过的路由器数量,由于 TTL 占 8 位,因此,数据报可在互联网中可经过的路由器数量的最大值为 255。

不同操作系统中,默认的 TTL 不一样,常见默认值如下:

操作系统 / 设备 默认 TTL 值
Windows 128
Linux / Unix 64
Cisco 路由器 255
Solaris 255
FreeBSD / macOS 64
Android 64

TTL 默认值是否可修改?答案是"可以",以 Linux 系统为例。

查看当前值:

bash 复制代码
cat /proc/sys/net/ipv4/ip_default_ttl

临时修改:

bash 复制代码
echo 128 > /proc/sys/net/ipv4/ip_default_ttl

永久修改:

bash 复制代码
echo 'net.ipv4.ip_default_ttl = 128' >> /etc/sysctl.conf
sysctl -p

那如何直观理解 TTL 跳数?我们继续举个例子,比如我 ping www.baidu.com

上图显示 TTL=52 表示 ICMP 数据报经过了 64 - 52 = 12 个路由器。

验证是不是 12 个路由器:

sh 复制代码
[root@ism ~]# traceroute -T www.baidu.com
traceroute to www.baidu.com (183.2.172.17), 30 hops max, 60 byte packets
 1  _gateway (172.17.10.1)  0.482 ms * *
 2  192.168.11.1 (192.168.11.1)  0.418 ms * *
 3  * * *
 4  * * *
 5  * * *
 6  * * *
 7  113.96.4.234 (113.96.4.234)  38.721 ms * *
 8  * * *
 9  14.29.117.178 (14.29.117.178)  30.439 ms  32.970 ms  34.381 ms
10  * * *
11  * * *
12  * * *
13  183.2.172.17 (183.2.172.17)  34.743 ms  35.205 ms *

traceroute 输出中,最后成功到达目标主机 183.2.172.17 是在第 13 跳

说明:

172.17.10.1:这是我本地的三层交换机,具备网络层,所以这里 TTL 会 -1

192.168.11.1:这是我本地的路由器,这里 TTL 也会 -1

所以:

  • 数据报在到达目标前经过了 12 个路由器(即跳数为 12);
  • 第 13 个 TTL 的数据包才到达目标主机;
  • TTL 初始值如果是 64,那么最终在目标返回时,你会在 ping 等工具里看到 ttl=52(64 - 12),如上图所示;
  • 实际中,跳数大于 30 就很少见了,一般公网路径 10~20 跳是常见范围
相关推荐
聊点儿技术3 小时前
利用IP归属地查询识别异地登录风险:企业账号安全的技术探索
数据库·tcp/ip·安全
晏宁科技YaningAI3 小时前
全球短信路由系统设计逻辑打破 80%送达率瓶颈:工程实践拆解
网络·网络协议·架构·gateway·信息与通信·paas
WIN-U64 小时前
新版华三H3C交换机配置NTP时钟步骤 示例(命令及WEB配置)
网络协议·tcp/ip·http
F1FJJ4 小时前
什么是 Shield CLI?视频讲解:一条命令,可浏览器远程访问一切内部服务(RDP/VNC/SSH/数据库等)
运维·网络·数据库·网络协议·ssh
F1FJJ5 小时前
Shield CLI 命令全解析:15 个命令覆盖所有远程访问场景
网络·数据库·网络协议·容器·开源软件
nbsaas-boot8 小时前
基于 HTTP 构建 MCP Tools 的完整工程解析
网络·网络协议·http·ai
i建模8 小时前
SSL: CERTIFICATE_VERIFY_FAILED feishu 机器人CoPaw
运维·网络·网络协议·ssl·openclaw
兰.lan8 小时前
【黑马ai测试】HTTP协议-抓包工具定位-弱网测试-缺陷介绍
网络·python·网络协议·http
liwulin050610 小时前
【ESP32-S3】WiFi 网页遥控 + WebSocket 实时控制编码电机+ 实时数据显示 + 急停 + 速度滑块
网络·websocket·网络协议
程序猿编码11 小时前
基于ncurses的TCP连接可视化与重置工具:原理与实现(C/C++代码实现)
linux·c语言·网络·c++·tcp/ip