linux抓包命令是什么

linux抓包命令是“tcpdump”,可以抓取流动在网卡上的数据包,可以将网络中传送的数据包的“头”完全截获下来提供分析;它支持针对网络层、协议、主机、网络或端口的过滤,并提供and、or、not等逻辑语句来帮助你去掉无用的信息。

linux抓包命令是什么

本教程操作环境:Red Hat Enterprise Linux 6.1系统、Dell G3电脑。

tcpdump命令是基于unix系统的命令行的数据报嗅探工具,可以抓取流动在网卡上的数据包。

顾名思义,tcpdump可以将网络中传送的数据包的“头”完全截获下来提供分析。它支持针对网络层、协议、主机、网络或端口的过滤,并提供and、or、not等逻辑语句来帮助你去掉无用的信息,tcpdump凭借强大的功能和灵活的截取策略,使其成为类UNIX系统下用于网络分析和问题排查的首选工具.

实用命令实例:

立即进入“豆包AI人工智官网入口”;

立即学习“豆包AI人工智能在线问答入口”;

(1).默认启动

#普通情况下,直接启动tcpdump将监视第一个网络接口上所有流过的数据包.[root@localhost ~]# tcpdump

(2).监视指定网络接口的数据包

[root@localhost ~]# tcpdump -i eth0 -c 10

(3).监视指定主机的数据包

[root@localhost ~]# tcpdump -i eth0 host 10.20.3.25

(4.).获取主机10.20.3.25发送的所有数据

[root@localhost ~]#tcpdump -i eth0 src host 10.20.3.25

(5).监视所有发送到主机10.20.3.25的数据包

[root@localhost ~]# tcpdump -i eth0 dst host 10.20.3.25

(6).监视指定主机和端口的数据包

[root@localhost ~]# tcpdump tcp port 22 and host 10.20.3.25

(7).监视指定网络的数据包,如本机与10.20.3网段通信的数据包,”-c 10″表示只抓取10个包

[root@localhost ~]# tcpdump -c 10 net 10.20.3

(8).抓取ping包

[root@localhost ~]# tcpdump -c 5 -nn -i eth0 icmp

(9).解析包数据

[root@localhost ~]# tcpdump -c 2 -q -XX -vvv -nn -i eth0 tcp dst port 22tcpdump: listening on eth0, link-type EN10MB (Ethernet), capture size 65535 bytes10:22:22.334383 IP (tos 0x0, ttl 63, id 26834, offset 0, flags [DF], proto TCP (6), length 40)    10.20.3.25.60401 > 10.20.9.131.22: tcp 0        0x0000:  0050 5685 2ba8 0074 9c0f c748 0800 4500  .PV.+..t...H..E.        0x0010:  0028 68d2 4000 3f06 b23a 0a14 0319 0a14  .(h.@.?..:......        0x0020:  0983 ebf1 0016 93e3 6ba8 cd6b d1ce 5010  ........k..k..P.        0x0030:  f6b4 0d8e 0000 0000 0000 0000            ............10:22:22.376759 IP (tos 0x0, ttl 63, id 26835, offset 0, flags [DF], proto TCP (6), length 40)    10.20.3.25.60401 > 10.20.9.131.22: tcp 0        0x0000:  0050 5685 2ba8 0074 9c0f c748 0800 4500  .PV.+..t...H..E.        0x0010:  0028 68d3 4000 3f06 b239 0a14 0319 0a14  .(h.@.?..9......        0x0020:  0983 ebf1 0016 93e3 6ba8 cd6b d392 5010  ........k..k..P.        0x0030:  faf0 078e 0000 0000 0000 0000            ............2 packets captured2 packets received by filter0 packets dropped by kernel[root@test-core-services-03 ~]#

(10).tcpdump抓取HTTP包

tcpdump  -XvvennSs 0 -i eth0 tcp[20:2]=0x4745 or tcp[20:2]=0x48540x4745 为"GET"前两个字母"GE",0x4854 为"HTTP"前两个字母"HT"。

tcpdump常用选项:

它的命令格式为:

tcpdump [ -DenNqvX ] [ -c count ] [ -F file ] [ -i interface ] [ -r file ]        [ -s snaplen ] [ -w file ] [ expression ]抓包选项:-c:指定要抓取的包数量。注意,是最终要获取这么多个包。例如,指定"-c 10"将获取10个包,但可能已经处理了100个包,只不过只有10个包是满足条件的包。-i interface:指定tcpdump需要监听的接口。若未指定该选项,将从系统接口列表中搜寻编号最小的已配置好的接口(不包括loopback接口,要抓取loopback接口使用tcpdump -i lo),            :一旦找到第一个符合条件的接口,搜寻马上结束。可以使用'any'关键字表示所有网络接口。-n:对地址以数字方式显式,否则显式为主机名,也就是说-n选项不做主机名解析。-nn:除了-n的作用外,还把端口显示为数值,否则显示端口服务名。-N:不打印出host的域名部分。例如tcpdump将会打印'nic'而不是'nic.ddn.mil'。-P:指定要抓取的包是流入还是流出的包。可以给定的值为"in"、"out"和"inout",默认为"inout"。-s len:设置tcpdump的数据包抓取长度为len,如果不设置默认将会是65535字节。对于要抓取的数据包较大时,长度设置不够可能会产生包截断,若出现包截断,      :输出行中会出现"[|proto]"的标志(proto实际会显示为协议名)。但是抓取len越长,包的处理时间越长,并且会减少tcpdump可缓存的数据包的数量,      :从而会导致数据包的丢失,所以在能抓取我们想要的包的前提下,抓取长度越小越好。输出选项:-e:输出的每行中都将包括数据链路层头部信息,例如源MAC和目标MAC。-q:快速打印输出。即打印很少的协议相关信息,从而输出行都比较简短。-X:输出包的头部数据,会以16进制和ASCII两种方式同时输出。-XX:输出包的头部数据,会以16进制和ASCII两种方式同时输出,更详细。-v:当分析和打印的时候,产生详细的输出。-vv:产生比-v更详细的输出。-vvv:产生比-vv更详细的输出。其他功能性选项:-D:列出可用于抓包的接口。将会列出接口的数值编号和接口名,它们都可以用于"-i"后。-F:从文件中读取抓包的表达式。若使用该选项,则命令行中给定的其他表达式都将失效。-w:将抓包数据输出到文件中而不是标准输出。可以同时配合"-G time"选项使得输出文件每time秒就自动切换到另一个文件。可通过"-r"选项载入这些文件以进行分析和打印。-r:从给定的数据包文件中读取数据。使用"-"表示从标准输入中读取。

相关推荐:《Linux视频教程》

以上就是linux抓包命令是什么的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/159361.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月5日 08:18:06
下一篇 2025年12月5日 09:25:49

相关推荐

  • Linux怎样查看mysql密码

    相信很多小伙伴都经历过忘记密码,如果在Linux下忘记MySQL密码该怎么办? Linux查看mysql密码具体方法。 查看默认密码 grep ‘temporary password’ /var/log/mysqld.log 或者 cat /var/log/mysqld.log | grep ‘te…

    数据库 2025年12月5日
    000
  • 详解Linux的用户空间与内核空间

    推荐:《linux视频教程》 一. 简介 Linux 操作系统和驱动程序运行在内核空间,应用程序运行在用户空间。两者不能简单地使用指针传递数据,因为Linux使用的虚拟内存机制,用户空间的数据可能被换出,当内核空间使用用户空间指针时,对应的数据可能不在内存中。用户空间的内存映射采用段页式,而内核空间…

    2025年12月5日 运维
    000
  • linux系统下fcntl函数解析与标准IO函数介绍

    —–今天是最后一篇文章关于linux系统下文件io操作了,从明天起开始写文件属性的文章了,欢迎大家来学习,一起进步。(同时也欢迎大家批评指出错误,我会及时纠正过来的)。 一、fcntl函数解析: 1、函数原型:先用man手册来查看fcntl的用法和原型: int fcntl(…

    2025年12月5日 运维
    000
  • linux如何统计文件个数

    linux统计文件个数的方法:1、查看路径下文件的个数,代码为【ls -l |grep “^-“|wc -l】;2、查看路径下文件夹的个数,代码为【ls -l |grep “^d”|wc -l】。 本教程操作环境:windows7系统、linux7.3…

    2025年12月5日
    000
  • linux find命令的用法有哪些

    linux find命令的用法有:1、【find -name】直接根据文件名字来查找;2、【find -perm】根据文件权限来查找;3、【find -mtine -n(+n)】根据文件的更改时间来查找。 相关学习推荐:linux视频教程 linux find命令的用法有: find命令是linux…

    2025年12月5日
    000
  • Firefox 144.0 发布

    firefox 144.0 已正式上线,本次更新带来多项新功能、改进与修复,具体内容如下: 新增功能 专注当前标签页,简化浏览界面现在即使折叠了标签页组,活动标签页仍会保留在视野中。这一改进帮助用户集中注意力于正在使用的页面,有效减少视觉混乱,提升工作效率。 更智能的标签页组操作标签页组功能进一步优…

    2025年12月5日
    000
  • Linux系统下如何运行.sh文件

    Linux系统下运行.sh文件的方法:首先输入该文件的绝对路径【/root/datelog.sh】;然后cd到【datelog.sh】文件的目录下,并执行【./datelog.sh】。 本教程操作环境:windows7系统、Linux7.3版本,Dell G3电脑。 Linux系统下运行.sh文件的…

    2025年12月5日 运维
    000
  • 怎么新建Python文件VSCode_VSCode创建Python文件教程

    答案:在VS Code中新建Python文件需打开软件后创建新文件并保存为.py格式,系统将自动启用Python语言服务。可通过快捷键Ctrl+N(Cmd+N)新建文件,再用Ctrl+S(Cmd+S)保存为.py文件以激活语法高亮和代码补全功能;也可通过菜单栏或资源管理器新建文件。为确保正常运行,需…

    2025年12月5日
    000
  • linux属于什么系统

    linux属于一种类UNIX操作系统。Linux,全称GNU/Linux,是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和Unix的多用户、多任务、支持多线程和多CPU的操作系统。 本文操作环境:red hat enterprise linux 7.4系统、thinkpad t4…

    2025年12月5日
    000
  • linux创建文件夹命令是什么

    linux创建文件夹命令是mkdir,语法为【mkdir (选项)(参数)】,其中Z为设置安全上下文,当使用SELinux时有效,version显示版本信息。 本文操作环境:linux2.6.32系统、DELL G3电脑。 Linux中 mkdir 创建文件夹命令 语法 mkdir (选项)(参数)…

    2025年12月5日 运维
    100
  • linux如何完全删除用户

    linux删除用户的方法:首先进入系统创建一个用户;然后对该用户一些信息目录查看;最后正确删除用户,代码为【[root@localhost /]# userdel -r haha】。 本教程操作环境:linux5.9.8,DELL G3电脑。 linux删除用户的方法: 1、首先进入系统创建一个用户…

    2025年12月5日 运维
    000
  • PHP一键环境与Docker容器化有什么区别_技术异同分析

    PHP一键环境与Docker本质区别在于封装与隔离方式:前者将服务直接安装于系统,多项目共用环境易冲突,适合新手和简单项目;后者通过容器镜像打包应用及依赖,实现环境隔离与一致,便于迁移和团队协作;一键环境部署直观但可移植性差,Docker学习成本高却支持自动化部署;资源上前者更轻量,后者虽有损耗但利…

    2025年12月5日
    000
  • 老电脑换Linux系统是否会更快,旧电脑不要装Windows!Bodhi Linux系统,小巧强悍,运行更流畅…

    大家好,又见面了,我是你们的朋友全栈君。 你的旧电脑安装win10还好吗? 随着科技的飞速发展,尤其是电脑硬件的不断更新换代,很多人不会轻易更换仅使用了两三年的电脑。 然而,电脑使用时间长了,性能难免会变慢,尤其是在Windows系统功能越来越多,占用资源越来越大的情况下,更换新电脑似乎是必然的选择…

    2025年12月5日 运维
    000
  • linux修改主机名的方法

    linux修改主机名的方法:1、在network中把HOSTNAME后面的值更改为想要设置的主机名;2、将hosts中的localhost.localdomian改为想要设置的主机名即可。 本教程操作环境:centos7系统、DELL G3电脑。 推荐:linux视频教程 Linux系统下修改主机名…

    2025年12月5日 运维
    000
  • linux下的文件重命名命令是什么

    linux下的文件重命名命令是mv。mv命令用来为文件或目录改名或将文件由一个目录移入另一个目录中,例如【$ mv test.txt wbk.txt】,表示将文件test重命名为webk。 本文操作环境:red hat enterprise linux 6.1系统、thinkpad t480电脑。 …

    2025年12月5日
    000
  • linux怎么查看防火墙状态

    linux查看防火墙状态的方法:可以通过执行【chkconfig –list iptables】命令来查看防火墙状态。如果要开启防火墙,可以执行【chkconfig iptables on】命令。 本文操作环境:red hat enterprise linux 6.1系统、thinkpa…

    2025年12月5日
    000
  • linux查看防火墙是否开启

    linux查看防火墙是否开启的方法:首先使用“ifconfig”或“ip addr”命令查看一下linux主机的IP;然后用“service iptables status”命令查看防火墙是否开启即可。 文中演示环境:centos6系统、Dell G3电脑。 推荐:《linux视频教程》 linux…

    2025年12月5日 运维
    000
  • VSCode怎么更改鼠标颜色_VSCode自定义鼠标指针颜色与光标样式设置教程

    VSCode无法更改系统鼠标指针颜色,但可自定义编辑器内文本光标样式、颜色及行为。通过修改settings.json文件,可设置光标样式(如line、block、underline)、宽度、闪烁方式(如blink、smooth、solid)、颜色(via workbench.colorCustomi…

    2025年12月5日
    000
  • Composer如何安装依赖_项目依赖包添加与安装指南

    Composer是PHP依赖管理工具,通过composer.json定义依赖,执行composer install安装库并生成vendor目录和composer.lock锁定版本,确保团队环境一致;使用composer update更新依赖,可指定包名;冲突时可升级依赖、调整版本约束或使用diagn…

    2025年12月5日
    000
  • linux怎么样查看端口占用情况

    linux查看端口占用的方法:使用【lsof -i 端口号或者netstat -tunlp|grep 端口号】这两个命令都可以查看端口被什么进程占用。 本教程操作环境:linux7.3系统、DELL G3电脑。 linux查看端口占用的方法: 1、常用命令: (1)lsof -i 端口号 (2)ne…

    2025年12月5日 运维
    000

发表回复

登录后才能评论
关注微信