0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

在Linux中使用traceroute排查服务器网络问题

dyquk4xk2p3d 来源:网络技术联盟站 2023-03-06 10:25 次阅读

一、前言

作为网络工程师或者运维工程师,traceroute命令不会陌生,它的作用类似于ping命令,用于诊断网络的连通性,不过traceroute命令输出的命令会比ping命令丰富的多,可以跟踪从源系统到目标系统的路径。

很多工程师对traceroute命令仅停留在基础使用上,但是在真实的实战过程中,基础操作并不能解决问题。本文我将给大家介绍几个traceroute命令的使用例子,让你完全掌握traceroute命令,让我们直接开始吧!

二、前置知识

在正式介绍命令使用前,请大家看下以下拓扑图:

993d020e-bb91-11ed-bfe3-dac502259ad0.png

如图所示,电脑想要访问服务器,期间到底走电脑->R1->R2->R4->服务器还是走电脑->R1->R3->R4->服务器,这个是就可以通过traceroute命令实现,这也是traceroute命令的价值所在。

三、在Linux中安装traceroute命令

首先我们通过命令lsb_release -a看下我们的服务器是什么发行版:

root@ecs-adf0-0003:~#lsb_release-a
NoLSBmodulesareavailable.
DistributorID:Ubuntu
Description:Ubuntu20.04.4LTS
Release:20.04
Codename:focal

由输出可知,我们的系统是Ubuntu系统,所以安装traceroute命令如下:

aptinstalltraceroute

安装过程:

995bd08a-bb91-11ed-bfe3-dac502259ad0.png

如果您的Linux系统发行版是CentOS或者Fedora,可以使用yum install traceroute命令。

四、在Linux中使用traceroute命令

4.1 基本用法

traceroute命令最基本的用法是:

traceroutehost

命令执行后会显示到达目的地所需的路由器列表。

比如我们traceroute我们的博客网站:

traceroutewww.wljslmz.cn

执行结果:

99758e26-bb91-11ed-bfe3-dac502259ad0.png

如图所示,我们执行完traceroute www.wljslmz.cn命令后,看到从我的ecs服务器到达www.wljslmz.cn所在服务器一共经历了20台路由器,每台路由器响应的时间也都打印下来了。

4.2 更改等待时间

traceroute 中的默认等待时间是 3 秒,这个意思就是,假如有20台路由器,每经历一台路由器默认等待时间是3秒,如果我们想改变这个值,可以加一个参数-w

traceroute-w1www.wljslmz.cn

执行结果:

998d63ac-bb91-11ed-bfe3-dac502259ad0.png

4.3 更改收发数据包的数量

默认情况下,traceroute 一次发送 3 个包,假如想更改这个数量,可以使用-q参数,比如我现在把它改成5个包:

traceroute-q5www.wljslmz.cn

执行结果:

99afc082-bb91-11ed-bfe3-dac502259ad0.png

由此可见,现在每台路由器收发就变成了5个包了。

4.4 更改最大跳数

所谓跳数就是一次请求经历的路由器的数量,还是这张图:

993d020e-bb91-11ed-bfe3-dac502259ad0.png

比如流量走向是电脑->R1->R2->R4->服务器,那么其跳数是3.

traceroute 中默认单次查询的最大跳数是 30,可以扩展到 255。

如果想要更改这个参数,可以加上-m参数。

我们上面执行的跳数都是20,我们为了显示出效果,将这个值改为10:

traceroute-m10www.wljslmz.cn

执行结果:

9a0ee5da-bb91-11ed-bfe3-dac502259ad0.png

可以看到最大跳数改为10以后,原先经历20台路由器,现在输出显示只有10台,参数生效了。

4.5 更改TTL开始值

首先给大家解释一下什么是TTL。

TTL英文全称:Time To Live,翻译成中文就是生存时间,是网络技术中比较常见的专业术语。

如果你使用过ping命令,那么TTL经常会看到:

root@ecs-adf0-0003:~#pingwww.wljslmz.cn

执行结果:

9a2a3f6a-bb91-11ed-bfe3-dac502259ad0.png

TTL,专业点解释就是用于限制数据包在 Internet 传输系统中“存活”的时间,或者说数据包在被丢弃之前在网络中的时间限制。

如果你还是不明白,你就把TTL看作是跳数限制,目的是防止数据包在网络中永远流通,最大 TTL 值为 255。

数据包的 TTL 字段由发送方设置,并由到达目的地的路径上的每个路由器减少,路由器在转发 IP 数据包时将 TTL 值减一,当数据包 TTL 值达到 0 时,路由器将其丢弃并向始发主机发送回ICMP 消息。

9a4be20a-bb91-11ed-bfe3-dac502259ad0.png

这就是TTL的全部解释了,如果还想更深入的了解TTL的底层原理,瑞哥可以后期专门出一篇文章进行解释。

默认情况下,traceroute 将从第一个 TTL 开始,如果想要更改这个值,我们可以使用-f参数实现:

traceroute-f8www.wljslmz.cn

执行结果:

9a66915e-bb91-11ed-bfe3-dac502259ad0.png

可以看到我们这里是从第8个TTL开始的。

4.6 禁用主机名到 IP 地址的映射

我们在执行traceroute www.wljslmz.cn命令时,注意箭头所指的位置,会有域名的出现:

9a840fa4-bb91-11ed-bfe3-dac502259ad0.png

现在是因为域名比较少,假如你跟踪的服务器中间路由器涉及到的域名比较多,那么是不便于排查问题的,所以我们需要去除主机名到 IP 地址的映射,可以使用-n参数:

traceroute-nwww.wljslmz.cn

执行结果:

9aa8cc4a-bb91-11ed-bfe3-dac502259ad0.png

可以看到已经没有域名了。

4.7 更改跟踪路由目的端口

先问大家可以问题:traceroute www.wljslmz.cn这条命令跟踪的是什么端口?

答案是80端口,如果我们想更改这个目的端口,怎么办?

可以使用-p参数,比如改成跟踪其2222端口:

traceroute-p2222www.wljslmz.cn

执行结果:

9acd8a4e-bb91-11ed-bfe3-dac502259ad0.png

4.8 更改最大数据包大小

默认情况下,最大数据包为60字节,如下图箭头所示:

9b130876-bb91-11ed-bfe3-dac502259ad0.png

如果我们觉得跟踪的路由器数量比较多,一看就不止60字节,这个时候想调大,可以这样操作:

traceroutewww.wljslmz.cn200

执行结果:

9b349586-bb91-11ed-bfe3-dac502259ad0.png

可以看到直接在命令后加入数字即可。

我们尝试执行一下这条命令:

traceroutewww.wljslmz.cn1

猜一下执行结果中,最大数据包大小是多少?

1?

当然不是!

9b519a14-bb91-11ed-bfe3-dac502259ad0.png

我们看到最终的大小是28字节,也就是说这条命令只能用来限制最大大小,而不是设置多大,包就被过滤了,28字节是跟踪包的最小大小,你设置的值小于这个大小,那么不管用!

9bbd3616-bb91-11ed-bfe3-dac502259ad0.png

4.9 启用ipv4跟踪

traceroute-4www.wljslmz.cn

执行结果:

9bfdbe20-bb91-11ed-bfe3-dac502259ad0.png

4.10 启用ipv6跟踪

traceroute-6www.wljslmz.cn

执行结果:

9c2486fe-bb91-11ed-bfe3-dac502259ad0.png

说明我们的网站未支持ipv6.

4.11 使用ICMP ECHO

默认情况下,traceroute 命令使用 UDP 端口进行跟踪路由,要使用 ICMP ECHO,可以结合参数-I

traceroute-Iwww.wljslmz.cn

执行结果:

9c349c60-bb91-11ed-bfe3-dac502259ad0.png

4.12 将traceroute信息保存到文件

这个跟traceroute命令本身没有太大关系,有时候我们需要将traceroute的信息离线分析,这个时候就需要将traceroute返回信息持久化,我们可以使用以下命令:

traceroutewww.wljslmz.cn>wljslmz.txt

执行结果:

9c4ed8aa-bb91-11ed-bfe3-dac502259ad0.png

我们通过命令more wljslmz.txt来看下这个wljslmz.txt文件:

9c6ecc46-bb91-11ed-bfe3-dac502259ad0.png

五、总结

traceroute 命令是一个有用且易于运行的网络诊断工具,本文给大家介绍了12个traceroute 命令示例,希望本文能够对您使用traceroute 命令有所帮助,如果有问题可以在下方评论区与我讨论!

审核编辑 :李倩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Linux
    +关注

    关注

    87

    文章

    10992

    浏览量

    206745
  • 服务器
    +关注

    关注

    12

    文章

    8125

    浏览量

    82551
  • Traceroute
    +关注

    关注

    0

    文章

    4

    浏览量

    1610

原文标题:老板让我在Linux中使用traceroute排查服务器网络问题,幸好我收藏了这篇文章!

文章出处:【微信号:良许Linux,微信公众号:良许Linux】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    linux服务器和windows服务器

    ,这在满足个性化需求和增强服务器安全 性上具有优势。 Linux服务器还具有出色的性能和稳定性。相比之下,Windows服务器性能和稳定性
    发表于 02-22 15:46

    服务器远程不上服务器怎么办?服务器无法远程的原因是什么?

    运营商。 2.服务器网络问题 解决办法:通过路由图来确定是哪里的线路出现丢包,联系服务器商切换线路。 二、服务器问题 服务器带宽跑满、
    发表于 02-27 16:21

    无线CDMA时间同步服务器网络时间服务器)技术文档

    无线CDMA时间同步服务器网络时间服务器)技术文档目前市场上普遍使用的是GPS子母LED时钟,即各个数码子钟需要用GPS母钟来传送标准时间信息。使用的时候需要在室外合适位置架设GP
    发表于 03-01 14:16

    手机也能玩Linux服务器——NOKIA手机高端应用

      核心摘要:对于从事网络和系统管理工作的人士来说,如果你在出差的路上,或者有事不能上网而如果服务器有什么问题的话,怎么能够通过SecureCRT和PUTTY远程连接到Linux服务器
    发表于 11-28 14:05

    为你的 Linux 服务器加把锁

    80 或 8080 端口。总之一句话,不确定的话,就关了它先。一个最简单的,没有做过任何额外更改的 Linux 服务器上,你会看到 SSH、 RPC 和 NTPdate 运行在它们的公开端口上。不要
    发表于 12-31 11:01

    基于Linux驱动程序源码的网络打印服务器设计

    一台主机。为了一个局域网环境中共享使用一台USB口打印机,需要为该打印机配备一台服务器,然后通过共享设置实现打印机的网络共享。这种方式有几个方面的缺陷:需要占用一台服务器资源;耗电;
    发表于 06-20 07:39

    Linux和Windows下的登录和使用Linux服务器的方式

    关于登录Linux服务器的方式有很多种,本文重点介绍了Linux和Windows下的登录和使用Linux服务器的方式。
    发表于 07-05 07:54

    linux下怎么搭建服务器

    e、点击云服务器进入服务器管理界面:f、此时可以看到你的服务器的公网ip,比如我的(118.89.32.60),之后的所有服务器访问都是通过公网ip进行访问的,为了测试本地计算机是否能
    发表于 07-08 07:02

    Linux系统上搭建 Web 服务器

    项目开发中,服务器主机用的是 Linux 系统,服务器用 Tomcat,数据库为 Mysql。如果电脑主机是 Windows 系列系统,则需要在其上安装虚拟机,虚拟机中安装
    发表于 07-09 07:56

    一款基于Linux的嵌入式网络打印服务器设计

    ,导致无法打印;占用办公空间。随着嵌入式处理主频的不断提高,设计专门的嵌入式网络打印服务器已经成为共识。HP等很少的几家打印机公司几年以前就推出了这样的嵌人式设备,但基本上都只针对
    发表于 07-25 07:43

    如何在Web服务器中使用jscolor拾色

    我想在网络服务器中使用 jscolor 拾色来设置我的 Neopixels 的颜色 => 我找到了一个教程,但它是用 LUA 编写的 => 如何将颜色选择嵌入到我的代码中?我在哪里
    发表于 02-22 09:05

    排查Linux服务器性能问题工具

    如果你的Linux服务器突然负载暴增,告警短信快发爆你的手机,如何在最短时间内找出Linux性能问题所在?来看Netflix性能工程团队的这篇博文,看它们通过十条命令在一分钟内对机器性能问题进行诊断。
    的头像 发表于 09-16 09:16 689次阅读

    如何使用Checkmk监控Linux服务器

    `Checkmk` 是用于监控 Linux 服务器的最常用和用户友好的应用程序之一。它可以检查与您的 Linux 服务器连接的服务器状态、负
    的头像 发表于 02-17 10:46 795次阅读
    如何使用Checkmk监控<b class='flag-5'>Linux</b><b class='flag-5'>服务器</b>?

    Linux服务器常见的网络故障排查方法

    日常工作中我们有时会遇到服务器网络不通问题,导致服务器无法正常运行。要想解决服务器网络故障问题,通常要先进行
    的头像 发表于 04-14 15:47 2265次阅读

    常用linux网络排查命令

    今天浩道跟大家分享linux网络运维中常见的命令,掌握好这些命令,在排查故障时将会游刃有余!
    发表于 06-25 10:49 520次阅读