计算机网络基础 和 tcp 三次握手四次挥手,tcpdump抓包分析 协议过滤 分析,连接状态,标志位详解

简介: wireshark 软件过滤及转码使用 ,TCP tcpdump 连接状态,标志位详解


tcp 抓包命令 ,wireshark 软件过滤及转码使用 ,TCP tcpdump 连接状态,标志位详解

# tcpdump 抓包命令

tcpdump -i eht0  host 203.119.160.6 and tcp port 80  -w 1.cap

tcpdump  host 203.119.160.6 and tcp port 80  -w 1.cap


                                                # -i 指定网卡

                                                # -w 指定文件

                                                # host ip

                                                # and 并且 tcp 协议  端口

tcpdump host 203.119.160.6 and port not 22

                                                # and port not 不匹配端口


tcpdump -i eth0 -U -w - 'host 192.168.2.29 and (port 22222 or port 22221 or port 80)'


# tcp 协议 SYN ACK PSH FIN 说明

TCP(Transmission Control Protocol)传输控制协议

TCP是主机对主机层的传输控制协议,提供可靠的连接服务,采用三次握手确认建立一个连接:


位码即tcp标志位,有6种标示:

SYN(synchronous建立联机)

ACK(acknowledgement 确认)

PSH(push传送)

FIN(finish结束)

RST(reset重置)

URG(urgent紧急)

Sequence number(顺序号码)

Acknowledge number(确认号码)




# 三次握手

a 客户端,b 服务器,seq 请求, ack 携带信息:如a带来的信息,+1 服务器的信息打包为ack

第一次: 客户端 ---->  服务器端 :    SYN        ( seq=a )                            #  SYN 连接请求 ; seq 客户端标识 a  

                                                                                                                # 发包标志: SYN=1; ACK=0


第二次: 客户端 <----  服务器端 :    SYN-ACK ( seq=b;      ack=a+1   )    # SYN ACK  连接确认,并将消息给客户端知晓,且等客户回复确认连接

                                                                                                                # 标识:b 服务器,包ack  客户端标识+服务器答复 1 收到请求

                                                                                                                # 发包标志:SYN=1,ACK=1  让客户端发确认连接数据包

                                                                                                                # 服务器允许连接,(可以通信)


第三次: 客户端 ---->  服务器端 :    ACK         ( seq=b+a;  ack=b+1 )     # ACK 客户确认连接,seq 标识:服务器和客户端两个

                                                                                                               #  发向服务器,服务器收到后就不再回复了而是打开数据传输。

                                                                                                               # 发包标识 SYN=0,ACK=1

4. 服务器开始传输数据

# 四次挥手


客户端主动断开:

1. 客户端 ----> 服务器端 :  FIN      ( seq=a )                               # 客户端标识 a  发 FIN 断开请求

2. 客户端 <---- 服务器端 :  ACK     ( seq=a+1 )                          # 发请求:客户端标识+服务器响应 1 (收到断开请求)  给客户端

3. 客户端 <---- 服务器端 :  FIN      ( seq=b;  ack=a+1 )             # 发断开请求: 断开客户端a的请求  1 已经收到

3. 客户端 ----> 服务器端 :  ACK     ( seq=b+1)                           # 客户端b收到

# wireshark 软件过滤及转码使用

ip.addr==47.95.216.170                  # 过滤IP,指定为:47.95.216.170

tcp.port==443                                 # 过滤端口


ip.addr==47.95.216.170 and tcp.port==443

                                                        # 过滤ip 并且过滤端口


ip.addr == 47.95.216.170 and not tcp.port in {3306 25 443}

                                                        # 过滤ip 并且指定端口,不是这几个:3306 25 443


ip.src         ip.dst      ip.addr                    !                tcp.port                          

来源ip      目的ip      源或者目的地ip      非不匹配      指定tcp模块中的端口        




# tcp 分析报文

上图圈起来的就是封包详细信息(Packet Details Pane):

这是最重要的信息,用来查看协议中的每一个字段。而OSI七层模型分别为:物理层、数据链路层、网络层、传输层、会话层、表示层、应用层。

在封包信息中,每行对应的含义及在OSI模型中的对应关系如下:

  Frame: 物理层的数据帧概况 ->对应OSI七层模型中的【物理层】

  Ethernet II: 数据链路层以太网帧头部信息 ->对应OSI七层模型中的【数据链路层】

  Internet Protocol Version 4: 互联网层IP包头部信息 ->对应OSI七层模型中的【网络层】

  Transmission Control Protocol: 传输层T的数据段头部信息,此处是TCP ->对应OSI七层模型中的【传输层】

Hypertext Transfer Protocol: 应用层的信息,此处是HTTP协议 ->对应OSI七层模型中的【应用层】





# TCP tcpdump 连接状态,标志位详解

S, SYN

F, FIN

R, RST

P, PUSH



LISTEN:侦听来自远方的TCP端口的连接请求

 

SYN-SENT:再发送连接请求后等待匹配的连接请求(客户端)

 

SYN-RECEIVED:再收到和发送一个连接请求后等待对方对连接请求的确认(服务器)

 

ESTABLISHED:代表一个打开的连接

 

FIN-WAIT-1:等待远程TCP连接中断请求,或先前的连接中断请求的确认

 

FIN-WAIT-2:从远程TCP等待连接中断请求

 

CLOSE-WAIT:等待从本地用户发来的连接中断请求

 

CLOSING:等待远程TCP对连接中断的确认

 

LAST-ACK:等待原来的发向远程TCP的连接中断请求的确认

 

TIME-WAIT:等待足够的时间以确保远程TCP接收到连接中断请求的确认

 

CLOSED:没有任何连接状态

主动端可能出现的状态:FIN_WAIT1、FIN_WAIT2、CLOSING、TIME_WAIT

# 网络层次划分

简书:https://www.jianshu.com/p/d3725391af59

tcp协议说明:https://blog.csdn.net/qq_25948717/article/details/80382766

tcp报文:https://blog.csdn.net/LL845876425/article/details/90143936

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
1月前
|
负载均衡 网络协议 算法
|
7天前
|
负载均衡 网络协议 算法
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
这网络层就像搭积木一样,上层协议都是基于下层协议搭出来的。不管是ping(用了ICMP协议)还是tcp本质上都是基于网络层IP协议的数据包,而到了物理层,都是二进制01串,都走网卡发出去了。 如果网络环境没发生变化,目的地又一样,那按道理说他们走的网络路径应该是一样的,什么情况下会不同呢? 我们就从路由这个话题聊起吧。
26 4
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
|
3天前
|
网络协议
TCP报文格式全解析:网络小白变高手的必读指南
本文深入解析TCP报文格式,涵盖源端口、目的端口、序号、确认序号、首部长度、标志字段、窗口大小、检验和、紧急指针及选项字段。每个字段的作用和意义详尽说明,帮助理解TCP协议如何确保可靠的数据传输,是互联网通信的基石。通过学习这些内容,读者可以更好地掌握TCP的工作原理及其在网络中的应用。
|
3天前
|
网络协议 安全 网络安全
探索网络模型与协议:从OSI到HTTPs的原理解析
OSI七层网络模型和TCP/IP四层模型是理解和设计计算机网络的框架。OSI模型包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,而TCP/IP模型则简化为链路层、网络层、传输层和 HTTPS协议基于HTTP并通过TLS/SSL加密数据,确保安全传输。其连接过程涉及TCP三次握手、SSL证书验证、对称密钥交换等步骤,以保障通信的安全性和完整性。数字信封技术使用非对称加密和数字证书确保数据的机密性和身份认证。 浏览器通过Https访问网站的过程包括输入网址、DNS解析、建立TCP连接、发送HTTPS请求、接收响应、验证证书和解析网页内容等步骤,确保用户与服务器之间的安全通信。
25 1
|
29天前
|
安全 搜索推荐 网络安全
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
55 11
|
18小时前
|
前端开发 网络协议 安全
【网络原理】——HTTP协议、fiddler抓包
HTTP超文本传输,HTML,fiddler抓包,URL,urlencode,HTTP首行方法,GET方法,POST方法
|
28天前
|
监控 网络协议 网络性能优化
网络通信的核心选择:TCP与UDP协议深度解析
在网络通信领域,TCP(传输控制协议)和UDP(用户数据报协议)是两种基础且截然不同的传输层协议。它们各自的特点和适用场景对于网络工程师和开发者来说至关重要。本文将深入探讨TCP和UDP的核心区别,并分析它们在实际应用中的选择依据。
56 3
|
1月前
|
网络协议 网络安全 网络虚拟化
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算。通过这些术语的详细解释,帮助读者更好地理解和应用网络技术,应对数字化时代的挑战和机遇。
106 3
|
1月前
|
网络虚拟化
生成树协议(STP)及其演进版本RSTP和MSTP,旨在解决网络中的环路问题,提高网络的可靠性和稳定性
生成树协议(STP)及其演进版本RSTP和MSTP,旨在解决网络中的环路问题,提高网络的可靠性和稳定性。本文介绍了这三种协议的原理、特点及区别,并提供了思科和华为设备的命令示例,帮助读者更好地理解和应用这些协议。
68 4
|
1月前
|
网络协议 安全 Go
Go语言进行网络编程可以通过**使用TCP/IP协议栈、并发模型、HTTP协议等**方式
【10月更文挑战第28天】Go语言进行网络编程可以通过**使用TCP/IP协议栈、并发模型、HTTP协议等**方式
62 13