t-tcpdump
文章目录
- 写入和读取数据包
- 抓取数据包
- 抓取指定网卡流量
- 指定数据的输出格式
- 数据包抓取的方向
- 输出信息的详细程度的可控选项
- 抓取指定协议的数据包
- 表达式介绍
- 逻辑连接符的使用
- type的确定
写入和读取数据包
在工作或者生活中的网络故障排除时最有力的方式就是抓包分析网络状况,从而找到网络故障的原因。所以将数据包保存到文件中,可以方便得进行分析取证。
数据包的写入命令
tcpdump -w test1.txt
数据包的读取命令
tcpdump -r test1.txt
数据包的多个文件读取
tcpdump -V pack.txt
其中pack.txt中包含多个数据包文件test1.txt,test2.text,test3.txt
抓取数据包
停止抓取数据包:
ctrl+c
- 终止
tcpdump
进程 - 抓取指定数量的数据包
tcpdump -c 5
数据包的状态
captured
当前tcpdump抓取的数据包个数received by filter
系统接收的数据包,tcpdump不一定过滤所有通过系统的数据包,系统数据包多于tcpdump抓取的数据包dropped by filter
tcpdump丢弃的数据包
抓取指定网卡流量
一台网络服务器可能有多个网卡连接不同的网络(可能即连接交换机,又连接路由器),对于分析不同的网络状态,需要针对指定的网卡进行分析
- 查看网卡
tcpdum -D
其中标记为up的为可以抓取的网卡root@ubuntu:/home/zhanghuigui/Desktop/tcpdum# tcpdump -D 1.ens33 [Up, Running] 2.any (Pseudo-device that captures on all interfaces) [Up, Running] 3.lo [Up, Running, Loopback] 4.bluetooth0 (Bluetooth adapter number 0) 5.nflog (Linux netfilter log (NFLOG) interface) 6.nfqueue (Linux netfilter queue (NFQUEUE) interface) 7.usbmon1 (USB bus number 1) 8.usbmon2 (USB bus number 2)
或者使用ifconfig -a
获取网卡信息 - 指定网卡的数据流量的抓取
tcpdum -i ens33
即可
指定数据的输出格式
默认情况下输出域名,而非ip地址和端口
tcpdum
以及tcpdum host
比如尝试访问百度的公共域名服务器,则只会看到抓取的数据包中包好域名信息,并未有ip地址和端口号
抓取的数据包中格式包含对应主机的ip和端口号
tcpdum -n
或者tcpdump host 180.76.76.76 -n
可以看到如下图中将原来的"域名+服务"转换为 “ip + 端口”,如public-dns-a.baidu.com.http
转换为180.76.76.76.80
数据包抓取的方向
- 抓取从目标ip流入当前设备的数据包 使用
-Q
参数,或者--direction
参数也可以
tcpdum host 180.76.76.76 -n -Q in
- 抓取从当前设备流入目标ip的数据包
tcpdump host 180.76.76.76 -n -Q out
- 抓取从当前设备的指定网卡 流入目标ip的数据包
tcpdump host 180.76.76.76 -n -Q out -i ens33
输出信息的详细程度的可控选项
- 输出链路层的mac地址通信信息
tcpdump host 180.76.76.76 -n -e
- 快速打印见面信息
tcpdump host 180.76.76.76 -n -q
- 更加详细得打印数据内容
以16进制形式打印,并用ascsII码输出打印的内容
tcpdump host 180.76.76.76 -n -X
更加详细的打印使用命令
tcpdump host 180.76.76.76 -n -XX
- 抓取过程中抓取相信信息并输出
tcpdump host 180.76.76.76 -n -v
或者tcpdump host 180.76.76.76 -n -vv
或者tcpdump host 180.76.76.76 -n -vvv
;-v
的个数越多,则打印的信息越相信
抓取指定协议的数据包
tcpdump icmp -n -v
仅抓取服务器接收到的 icmp协议的数据包
表达式介绍
表达式可以用来筛选想要的数据包内容,使用man pcap-filter
包含过滤器的过滤规则和语法
tcpdump的表达式使用规则如下:
tcpdump [option] [not] proto dir type
其中
option
是可选项,代表子命令-Q/-v/-n/-e/-c
not
可选项,表示取反,即表示抓取不符合not之后写的过滤规则的数据包proto
是必选项,表示支持的协议tcp/udp/arp/ip/icmp等
dir
是流入流出控制,src/dst/src and dst/src or dst
type
是筛选特定的ip和端口host/net/port/portrange
指定的ip,端口号,端口范围筛选
逻辑连接符的使用
tcpdump -n -v dst 180.76.76.76 and tcp
抓取发送终点为180.76.76.76服务器且协议为tcp的数据包
type的确定
常用的type为:host/port/portrange
tcpdump -q -n host 180.76.76.76
抓取type是host,ip地址为180.76.76.76的数据包
tcpdump -n -v host 180.76.76.76 and port 80
抓取ip地址为180.76.76.76端口为80的数据包
tcpdump -n -v net 180.76 and port 80
抓取范围为180.76.0.0 - 180.76.255.255,端口为80的数据包
tcpdump -n -v dst port 80
筛选目标端口为80端口的数据包
tcpdump -n -v dst port 80 and dst net 180.76
筛选目标端口为80,网段为180.76.0.0-180.76.255.255范围的数据包
相关文章:

java jdk 8u111_8u111-jdk-alpine在java开发中的NullPointerException错误解决方案
问题描述在部署一个验证码服务的容器服务时遇到了一个空指针错误,错误代码为:java.lang.NullPointerExceptionat sun.awt.FontConfiguration.getVersion(FontConfiguration.java:1264)at sun.awt.FontConfiguration.readFontConfigFile(FontConfiguratio…

sprintf函数做什么用?
sprintf函数原型为 int sprintf(char *str, const char *format, ...)。作用是格式化字符串,具体功能如下所示: (1)将数字变量转换为字符串。 (2)得到整型变量的16进制和8进制字符串。 (3&#…

Yii学习笔记【3】
加载控制器及其方法: 根据route信息,获得当前控制器| 初始化当前控制器,CController::init(),默认为空| 执行当前控制器,CController::run()||----> 创建action,为空则默认为index|得到CInlineAction的实…

验证码相似问题
产生随机验证码时,类似数字1和小写字母l经常容易让人混淆分不清楚, 因此,产生随机验证码时应避免此情况 1(一)、l(哎哦)、I (哎)中三个任意两个或者全部不可同时存在 0&a…

C语言网络编程:accept函数详解
文章目录前言函数描述代码实例如何得到客户端的IP 和 端口号前言 当使用tcp服务器使用socket创建通信文件描述符,bind绑定了文件描述符,服务器ip和端口号,listen将服务器端的主动描述符转为被动描述符进行监听之后,接口accept通过…

java 声明静态类_java静态类声明--java类可以声明为static吗
为了理解static关键字在类声明中的使用,首先我们需要了解类声明。有两种类,一种是top-level class;一种是inner class。Top-level classestop-level class可以被声明为包成员,每一个top-level类对应于一个文件名与类名相同的java文…

单元测试资料汇总
从安装到配置 首先到官网http://www.nunit.org/下载如下图的资料,安装NUnit-2.6.1.msi包。 然后挂在VS2010外部工具这个地方来使用,工具—>外部工具—>添加—>标题:Nunit—>命令:安装路径—>确定。 然后打开Nunit&…

rhel5+nis+autofs+nfs
创建NIS服务器用户,用于客户端登陆 NIS服务器相关包:ypserv、ypbind(在RHEL5中默认已安装)、yp-tools(在RHEL5中默认已安装)。 运行nisdomainname test.com并把加入到如下位置 设置NIS服务器的域名 在NIS环境中将以NIS服务器上的所有用户用于NIS环境中所…

Beta冲刺 (1/7)
Part.1 开篇 队名:彳艮彳亍团队 组长博客:戳我进入 作业博客:班级博客本次作业的链接 Part.2 成员汇报 组员1(组长)柯奇豪 过去两天完成了哪些任务 熟悉并编写小程序的自定义控件展示GitHub当日代码/文档签入记录接下来…

C语言网络编程:listen函数详解
文章目录前言函数描述代码实例TCP服务器为什么调用listen前言 根据TCP编程模型中我们可以看到之前的socket和bind接口是tcp服务器在为接收客户端的链接做准备,保证tcp的面向字节流,面向连接的可靠通信服务正常进行。接下来的listen端口则为我们进行三次…

MVC页面加载速度优化小记
前言:最近做一个地图展示页面,业务初期没什么问题,运行一阵后报错: Error during serialization or deserialization using the JSON JavaScriptSerializer. The length of the string exceeds the value set on the maxJsonLeng…

java生成函数excel_java实现在excel中创建及读取公式
操作excel表格用公式来处理数据时,可通过创建公式来运算数据,或通过读取公式来获取数据信息来源。这里使用了java类库(Free Spire.XLS for Java 免费版)获取文件包后,解压,将lib文件夹下的jar文件导入Java程序。如图:(…

实战:使用TCP/IP筛选保护服务器安全
使用TCP/IP筛选保护服务器安全 对于部署在Internet的服务器,安全是必须要考虑的事情。为了降低服务器受***的危险,停止不必要的服务或在本地连接的TCP/IP属性中只打开必要的端口。 如图2-127所示,实验环境为Server的IP地址192.168.1.200&…

python中的协程(二)
协程 1、协程: 单线程实现并发 在应用程序里控制多个任务的切换保存状态 优点: 应用程序级别速度要远远高于操作系统的切换 缺点: 多个任务一旦有一个阻塞没有切,整个线程都阻塞在原地,该线程内的其他的任务都不能执行…

C语言网络编程:bind函数详解
文章目录函数功能函数头文件函数使用函数参数函数举例为什么需要bind函数服务器如何知道客户端的ip和端口号htons函数htons兄弟函数htonl,ntohs,ntohl为什么要进行端口的大小端序的转换inet_addr函数函数功能 bind API能够将套接字文件描述符、端口号和ip绑定到一起 注意&…

java flex 图片上传_flex上传图片到java服务器
今天弄flex上传图片到java,现在弄成功,中间也经常一点小波折,现记录一下。重点在java侧的实现。flex侧:文件上载到在url参数中传递的URL。该URL必须是配置为接受上载的服务器脚本。Flash Player使用HTTP POST方法上载文件。处理上…

开发者怎么样做到盈利
开发者如何赚钱? 不可回避的一点就是,开发者的产品要有足够好的用户体验。假设你会做手机游戏,那么把手游做好了之后用户的粘性很大,如果你做应用,那么你的应用下载会对用户产生有价值的东西。 其实如果你的产品真的有价值&#…

如何在Windows Azure VM上的SQL Server和Windows Azure SQL Database两者中做出选择
作者信息:本篇文章是由SQL Server Cloud Infrastructure Team的 Madhan Arumugam 和 Guy Bowerman共同著作。 简介 把SQL 数据托管在哪里,Windows Azure 为您提供了两个选择,VM上的SQL Server(以下简称 SQL/VM)和 Wind…

C语言网络编程:socket函数
函数描述 头文件 <sys/types.h> <sys/socket.h> 函数使用int socket(int domain, int type, int protocol); 函数功能:创建一个通信的终点,并返回一个文件描述符来代表通信的终点 函数参数: a. domain 代编当前创建的socket文…

python excel web_使用python在WEB页面上生成EXCEL文件
近日写的一个程序需要在WEB服务器上生成EXCEL文件供用户下载,研究了一下找到了以下比较可行的实现方案,下面以web.py为例,把相关代码贴出来供大家参考:首先需要下载生成EXCEL的模块,推荐使用xlwtimport xlwtimport Str…

dateTimePicker编辑状态下,取值不正确的问题
当对dateTimePicker进行编辑,回车,调用函数处理dateTimePicker的value值时,其取值结果是你编辑之前的值,而不是你编辑后的值,虽然dateTimePicker.text的值是编辑后的值,但使用起来不方便,因此暂…

RMAN Backups
oracle 主要的备份工具 RMAN 其中,open database backup, 不需要把数据库设置成backup状态, RMAN reads a block until a consistent read is obtained. 看来备份比较重要的三种文件分别是, data file, control file, archivelog file. Types of Recovery Manager B…

异步使用委托delegate --- BeginInvoke和EndInvoke方法
当我们定义一个委托的时候,一般语言运行时会自动帮委托定义BeginInvoke 和 EndInvoke两个方法,这两个方法的作用是可以异步调用委托。 方法BeginInvoke有两个参数: AsyncCallBack:回调函数,是一个委托,没有…

C语言网络编程:TCP编程模型
编程模型 TCP编程模型如下 TCP服务器的工作过程如下: 服务器创建一个专门的“文件描述符”来监听来自客户端的“三次握手”,然后建立链接链接建立成功后,服务器会分配一个专门的“通信文件描述符”,用于实现与该客户端的通信 …

九度 1553:时钟(模拟题)
题目描述:如图,给定任意时刻,求时针和分针的夹角(劣弧所对应的角)。 输入:输入包含多组测试数据,每组测试数据由一个按hh:mm表示的时刻组成。 输出:对于每组测试数据,输出一个浮点数,…

python3.7.4安装教程桌面_Python 3.7.4 for Windows的安装
一、Python简介Python是一款通用型的计算机程序设计语言,Python对编程人员来讲是一款很是有利的工具,可让您快速编写代码,并且代码运行速度很是快。Python具备很是简捷而清晰的语法特色,适合完成各类高层任务,几乎能够…

CSS 合法颜色值
2019独角兽企业重金招聘Python工程师标准>>> 连接地址:http://www.w3school.com.cn/css/css_colors_legal.asp 转载于:https://my.oschina.net/syc2013/blog/109970

SQL 关于apply的两种形式cross apply 和 outer apply
SQL 关于apply的两种形式cross apply 和 outer apply阅读目录 SQL 关于apply的两种形式cross apply 和 outer applySql学习第四天——SQL 关于with cube ,with rollup 和 grouping回到目录SQL 关于apply的两种形式cross apply 和 outer apply SQL 关于apply的两种形…

C语言网络编程:TCP客户端实现
文章目录客户端通信步骤为什么客户端没有bind和listen客户端connect函数介绍局域网内客户端和服务器通信代码实例客户端通信步骤 根据基本TCP网络通信编程模型 我们可以知道客户端的实现主要有几个步骤 socket创建客户端通信的套接字文件,并指定通信的协议族和数…

java不能对什么类型进行转换_关于java:“不兼容类型:void无法转换为…”是什么意思?...
Java编译消息是什么:"Incompatible types: void cannot be converted to ..."的意思,以及我该如何解决。 一些编译器使用不同的措词; 例如"Type mismatch: cannot convert from void to ..."要么"Incompatible type…