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

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

3天内不再提示

在Linux中如何使用tcp转储命令来分析网络

汽车电子技术 来源:嵌入式悦翔园 作者:JamesBin 2023-02-17 10:04 次阅读

前言

Tcpdump是用于分析网络和查找相关网络问题的出色工具。它会在数据包经过时捕获数据包,并向您显示网络上正在发生的事情和传入情况。该命令的输出显示在 STDOUT 上,也可以存储在文件中。

感谢开发人员,他们将Tcpdump保留为开源项目。它可以在Unix和Linux系统上免费获得。视窗有一个“微海外杠TCPDUMP用于视窗”变体,并带有相关的价格标签

tcpdump有一长串可用的选项。在本文中,我将重点介绍经常使用的核心选项。

检查可用接口

要检查要捕获的所有可用接口,请使用-D标志作为:

sudo tcpdump -D

这将列出系统上的所有接口,包括无线和有线接口等。该标志也可以获得相同的功能:--list-interfaces

sudo tcpdump --list-interfaces

图片

在这里插入图片描述

捕获特定接口的数据包

在不使用任何选项的情况下,Tcpdump 将扫描所有接口。该标志捕获来自特定接口的流量:-i

tcpdump -i <target-interface>

将 替换为要扫描的接口的名称。例如,在 接口 的情况下,此命令将作为:target-interfaceeth0

sudo tcpdump -i eth0

注意:从现在开始,我将使用 or 作为目标接口。因此,无论您在何处看到 -i 标志,它都将伴随界面或 eth0 eth1 eth0 eth1

预设捕获计数

该标志可用于预设要捕获的数据包数-c

例如,我们将此值设置为 4 以捕获四个数据包。在本例中,该命令将为:

sudo tcpdump -c 4 -i eth0

图片如果未指定计数,则将使用组合键或 手动中断捕获操作。ctrl+cctrl+z

在下面的文章中,我将根据需要将标志与其他标志一起添加。这将有助于我们清晰,轻松地理解命令的输出。-c

获取详细输出

要获取命令的详细输出,可以使用标志:tcpdump-v

sudo tcpdump -c 6 -v -i eth0

您可以使用更多标志 as 或 进一步提高详细程度。这将在终端上产生更详细的输出:-v -vv -vvv

sudo tcpdump -vv -i eth0

以 ASCII 格式打印捕获的数据

有时,我们可能要求 Tcp 转储输出采用十六进制或 ASCII 格式。我们可以使用 ASCII 格式以及 ASCII 和十六进制格式的选项来解决这个问题:-A- XX

sudo tcpdump -XX -i eth0

图片

在这里插入图片描述

捕获从特定源 IP 发送的数据包

如果要检查来自特定源 IP 地址的流量,请使用以下命令:

sudo tcpdump -i eth0 src address>

让我们将源 IP 作为并查看流量的详细信息192.168.56.11

sudo tcpdump -i eth1 -c 5 src 192.168.56.11

图片此处的计数 5 将仅捕获前五个数据包。

捕获发送到特定目标 IP 的数据包

如果要检查发送到特定目标 IP 地址的流量,请使用以下命令:

sudo tcpdump -i eth0 dst address>

让我们将目标 IP 作为并查看流量的详细信息:192.168.56.11

sudo tcpdump -i eth1 -c 5 dst 192.168.56.11

图片

在这里插入图片描述

将过滤选项与 Tcp 转储结合使用

这是缩小捕获数据范围以进行检查的好方法。这将消除不必要的流量并简化您的工作。为此,您可以根据主机、端口、协议和其他条件筛选流量。

让我们看看其中的一些:

端口号

如果要根据端口号过滤流量,例如端口 22,则按如下方式执行命令:tcpdump

sudo tcpdump -i eth0 port 22

此命令将捕获 TCP 和 UDP 流量。

协议

与端口指令类似,该指令根据特定流量过滤数据包捕获。在这里,您可以使用协议名称或协议编号作为参数值:proto

sudo tcpdump -i eth0 proto tcp
sudo tcpdump -i eth0 proto 6

令您惊讶的是,上面的两个命令是等效的。这是因为 是 TCP 的协议编号。6

主机过滤器

host 参数只是使用其 IP 过滤来自特定主机的流量:

sudo tcpdump -i eth0 host 192.168.56.10

这将捕获所有流量并从此主机流出。有趣的是,您可以将多个过滤器应用于主机,以针对特定类型的数据包流量。

例如:

sudo tcpdump -i eth1 -c 50 “(host 192.168.56.11) and (port 443 or port 80)"

图片在这里,我将不同的过滤规则合并到一个规则中。您可以看到此规则是过滤和流量。这是因为该规则包含端口 80443(公共网络端口)的筛选器。http https

保存捕获的数据

如果要将捕获的数据存储在文件中,可以这样操作。

sudo tcpdump -i eth0 -c 10 -w my_capture.pcap

图片将数据包计数保持在较小的值;否则,您可能需要手动停止该过程。

读取捕获的数据

您可以使用存储在文件中的数据与Wireshark或任何其他图形网络协议分析器进行分析。.pcap

您可以使用 tcp 转储本身来读取它。

tcpdump -r my_capture.pcap

图片上面的屏幕截图显示了上述文件的数据。my_capture.pcap

结语

希望您对如何使用不同的方式使用tcpdump命令有一个很好的想法。当您从远程无外设计算机捕获数据包时,这是最佳选择。

如果您想要一种更直观的方式来理解数据包捕获,请尝试使用Wireshark。

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

    关注

    14

    文章

    7251

    浏览量

    87447
  • 文件
    +关注

    关注

    1

    文章

    540

    浏览量

    24402
  • 数据包
    +关注

    关注

    0

    文章

    231

    浏览量

    24095
收藏 人收藏

    评论

    相关推荐

    Linux中使用tcp转储命令分析网络

    Tcpdump是用于分析网络和查找相关网络问题的出色工具。它会在数据包经过时捕获数据包,并向您显示网络上正在发生的事情和传入情况。该命令的输
    发表于 11-15 11:47 479次阅读

    嵌入式系统基础之LINUX使用入门, Linux的常用网络命令:nslookup

    大家都说linux网络功能很强大,装了一台linux,只会用ping和ifconfig命令,linux还用哪些有用的,常用的
    发表于 12-16 10:12

    Modbus TCPModbus RTU的实现

    、仪表上用得更为普遍。不同的设备遵守Modbus标准之后可以互相通信的目的。Modbus最初是使用串行链路的,例如RS232、RS485/422,随着网络的发展,后来又推出了Modbus TCP标准
    发表于 08-10 10:04

    什么是LinuxLinux命令的基本格式是什么?

    什么是LinuxLinux命令行操作的特色是什么?Linux命令的基本格式是什么?
    发表于 07-01 09:51

    基于TCP/IP的网络通信应用程序分享

    基于TCP/IP的网络通信应用程序(TCP-Server)上一篇文章讲述了i.MX6UL开发板,以客户端的角色,使用
    发表于 12-23 08:12

    Linux内核网络TCP传输控制块相关资料分享

    1、Linux内核网络之传输层接收消息简析传输层发送消息时,TCP发送出去消息后,会跟踪这些数据包,直到得到对方的确认为止。对于接收方来讲,当收到一个报文段时,其会根据情况把这些数据
    发表于 06-21 16:53

    有什么方法可以追溯地将加密标志应用于现有加密设备上的核心分区?

    ,所以我们可以进行崩溃分析......不幸的是,当我们开发固件启用代码时,我们在运行时尝试读取核心数据时很快遇到以下错误:E (41
    发表于 03-02 08:01

    Linux的常用网络命令

    Linux的常用网络命令 Linux 的常用网络命令  计算机
    发表于 01-18 12:47 1119次阅读

    Linux服务器性能测试及分析命令大全

    Linux服务器性能测试及分析命令大全
    发表于 09-05 15:42 12次下载
    <b class='flag-5'>Linux</b>服务器性能测试及<b class='flag-5'>分析</b><b class='flag-5'>命令</b>大全

    基于TCP/IP协议的网络连接网络管理命令

    通过本实验,初步掌握了TCP/IP设置,以及网络共享的基本知识,以及常用网络管理命令的使用。通过输入命令符,查询计算机的ip以及路由等相关信
    发表于 09-20 17:19 9次下载
    基于<b class='flag-5'>TCP</b>/IP协议的<b class='flag-5'>网络</b>连接<b class='flag-5'>网络</b>管理<b class='flag-5'>命令</b>

    linux命令无法使用怎么办

    linux命令无法使用是怎么回事?问题分析
    发表于 05-28 09:02 1728次阅读
    <b class='flag-5'>linux</b>中<b class='flag-5'>命令</b>无法使用怎么办

    如何使用ip命令Linux中进行网络管理

    Linux中,'ip'命令是管理网络方面最强大的命令之一。该命令可以允许用户在不使用任何其他
    发表于 05-31 12:25 220次阅读

    常用linux网络排查命令

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

    shell命令linux命令一样吗

    Shell命令Linux命令并不完全一样。 首先,Shell是一种命令行解释器,它是用来解释和执行用户输入的命令的。Shell既是一种
    的头像 发表于 11-08 10:51 1388次阅读

    linux系统修改ip命令

    Linux系统修改IP命令是掌握Linux网络管理的基础之一。在Linux操作系统中,我们可以使用命令
    的头像 发表于 11-27 15:17 1161次阅读