计算机网络基础 和 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

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
11月前
|
数据采集 算法 数据挖掘
模块化控制协议(MCP)在网络中增强智能体执行效率的研究
随着Web3技术的迅速发展,去中心化应用和智能体在各种领域的应用逐渐增多。MCP(Modularized Control Protocol,模块化控制协议)作为一种增强智能体执行能力的关键技术,为Web3场景中的智能体提供了更强的灵活性和可扩展性。本文将探讨如何利用MCP技术提升智能体在Web3场景中的执行能力,并通过实例代码展示其实现路径。
1070 22
|
8月前
|
监控 负载均衡 安全
WebSocket网络编程深度实践:从协议原理到生产级应用
蒋星熠Jaxonic,技术宇宙中的星际旅人,以代码为舟、算法为帆,探索实时通信的无限可能。本文深入解析WebSocket协议原理、工程实践与架构设计,涵盖握手机制、心跳保活、集群部署、安全防护等核心内容,结合代码示例与架构图,助你构建稳定高效的实时应用,在二进制星河中谱写极客诗篇。
WebSocket网络编程深度实践:从协议原理到生产级应用
|
9月前
|
运维 架构师 安全
二层协议透明传输:让跨域二层协议“无感穿越”多服务商网络
简介:本文详解二层协议透明传输技术,适用于企业网工、运营商及架构师,解决LLDP/LACP/BPDU跨运营商传输难题,实现端到端协议透传,提升网络韧性与运维效率。
|
安全 网络协议 Linux
Linux网络应用层协议展示:HTTP与HTTPS
此外,必须注意,从HTTP迁移到HTTPS是一项重要且必要的任务,因为这不仅关乎用户信息的安全,也有利于你的网站评级和粉丝的信心。在网络世界中,信息的安全就是一切,选择HTTPS,让您的网站更加安全,使您的用户满意,也使您感到满意。
398 19
|
安全 网络安全 定位技术
网络通讯技术:HTTP POST协议用于发送本地压缩数据到服务器的方案。
总的来说,无论你是一名网络开发者,还是普通的IT工作人员,理解并掌握POST方法的运用是非常有价值的。它就像一艘快速,稳定,安全的大船,始终为我们在网络海洋中的冒险提供了可靠的支持。
393 22
|
网络协议 数据安全/隐私保护 网络架构
|
缓存 网络协议 API
掌握网络通信协议和技术:开发者指南
本文探讨了常见的网络通信协议和技术,如HTTP、SSE、GraphQL、TCP、WebSocket和Socket.IO,分析了它们的功能、优劣势及适用场景。开发者需根据应用需求选择合适的协议,以构建高效、可扩展的应用程序。同时,测试与调试工具(如Apipost)能助力开发者在不同网络环境下优化性能,提升用户体验。掌握这些协议是现代软件开发者的必备技能,对项目成功至关重要。
|
机器学习/深度学习 人工智能 网络协议
TCP/IP五层(或四层)模型,IP和TCP到底在哪层?
TCP/IP五层(或四层)模型,IP和TCP到底在哪层?
689 4
|
域名解析 网络协议
IP协议, TCP协议 和DNS 服务分别是干什么的?
大家好,我是阿萨。昨天讲解了网络四层协议[TCP/IP协议族分为哪4层?]今天我们学习下IP 协议, TCP 协议和DNS 协议分别是干什么的。
714 0
IP协议, TCP协议 和DNS 服务分别是干什么的?
|
网络协议
ACK的累加规则-wireshark抓包分析-不包含tcp头部、ip头部、数据链路层头部等。
ACK的累加规则-wireshark抓包分析-不包含tcp头部、ip头部、数据链路层头部等。
ACK的累加规则-wireshark抓包分析-不包含tcp头部、ip头部、数据链路层头部等。