【计算机网络-传输层】TCP/UDP、SYN泛洪攻击、三次握手四次挥手

简介: 【计算机网络-传输层】TCP/UDP、SYN泛洪攻击、三次握手四次挥手

1. UDP

  • UDP无连接的,减少开销和发送数据之间的延迟
  • UDP使用最大努力交付,即不保证可靠交付
  • UDP是面向报文的(直接将整个应用层传过来的报文封装),适合一次性传输少量数据的网络应用。
  • UDP没有拥塞控制(IP电话、腾讯会议),如果拥塞太过严重,直接重传报文~
  • UDP首部开销小,8个字节(8B)–16位源端口号(可有可无)–16位目的端口号(必须要有)–16位UDP长度(整个数据的长度)–16位UDP检验和(检验是否出错

2. TCP

2.1 特点

  • TCP是面向连接的传输层协议
  • 每一条TCP连接只能有两个端点,每一条TCP连接只能是点对点
  • TCP提供可靠交付的服务,无差错、不丢失、不重复、按序到达。可靠有序,不丢不重
  • TCP提供全双工通信:发送缓存(准备发送的数据&已发送但尚未收到确认的数据)接受缓存(按序到达但尚未被接受应用程序读取的数据&不按序到达的数据)
  • TCP面向字节流:TCP把应用程序看成仅仅是一连串的无结构的字符流(字节序列)

2.2 TCP报文段首部格式

  • 序号seq:TCP发送报文段中第一个字节的值
  • 确认号ack:期望收到对方下一个报文段的第一个字节的值
  • 数据偏移:TCP首部的长度
  • URG:URG = 1,紧急数据,让我先传(插队),冲冲冲~~~
  • 确认位ACK:ACK = 1时,确认号有效,ACK = 0,确认号无效,在连接建立后所有传送的报文段都必须吧ACK置为1
  • 推送位PSH:如果该位为1的话,就赋予了一个优先级,交给上面
  • 复位RST:大多数用来出现差错,重新连接
  • 同步位SYN:SYN = 1时,表示这是一个请求连接的报文段
  • 终止位FIN:FIN = 1,表明释放连接
  • 紧急指针:就是URG中紧急数据的长度

2.3 TCP的连接管理

TCP连接传输三个阶段:连接建立-----数据传送-----连接释放

TCP连接的建立采用客户服务器方式,主动发起连接建立的应用进程叫做客户,而被动等待连接建立的应用进程叫服务器。

2.3.1 TCP三次握手

  • 第一次握手(SYN = 1、seq = x(随机),ACK = 0):客服端发送连接请求报文段,无应用层数据
  • 第二次握手(SYN = 1,ACK = 1,seq = y(随机), ack = x + 1):服务器为该TCP连接分配缓存和变量,并向客户端返回确认报文段,允许连接,无应用层数据
  • 第三次握手(SYN = 0,ACK = 1, seq = x + 1, ack = y + 1):客户端为该TCP连接分配缓存和变量,并向服务器返回确认的确认,可以携带数据。

2.3.2 SYN洪泛攻击

2.3.3 TCP的4次挥手

  • 第一次挥手(FIN = 1,seq = u):客户端发送连接释放报文段,停止发送数据,主动关闭TCP连接
  • 第二次挥手(ACK = 1,ack = u + 1, seq = v):服务器返回一个确认报文段,客户到服务器这个方向的连接就释放了–半关闭状态
  • 第三次挥手(FIN = 1,ack = u + 1, seq = w,ACK = 1):服务器发完数据,就发出连接释放报文段,主动关闭TCP连接
  • 第四次挥手(ACK = 1, seq = u + 1,ack = w + 1):客户端回送一个确认报文段,在等待计时器设置的2MSL(最长报文段寿命后),连接彻底关闭。

2.3.4 2MSL的由来

客户端发送的第四次挥手报文段,没有发送到服务器

这时候服务器端会再次发送第三次挥手的内容,请求关闭

这时候客户端收到请求,再次发送4次挥手,服务器收到,双方关闭

如果没有2MSL的话,客户端直接关闭,这时候服务端就会重复的发送第三次挥手,服务器无法进入关闭状态

3. TCP、UDP的区别


相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
1月前
|
移动开发 网络协议 安全
网络面试题:什么是 TCP/IP?
网络面试题:什么是 TCP/IP?
43 0
网络面试题:什么是 TCP/IP?
|
4天前
|
存储 网络协议 关系型数据库
Python从入门到精通:2.3.2数据库操作与网络编程——学习socket编程,实现简单的TCP/UDP通信
Python从入门到精通:2.3.2数据库操作与网络编程——学习socket编程,实现简单的TCP/UDP通信
|
20天前
|
网络协议 安全 网络性能优化
|
20天前
|
Python
Python网络编程基础(Socket编程)UDP服务器编程
【4月更文挑战第8天】Python UDP服务器编程使用socket库创建UDP套接字,绑定到特定地址(如localhost:8000),通过`recvfrom`接收客户端数据报,显示数据长度、地址和内容。无连接的UDP协议使得服务器无法主动发送数据,通常需应用层实现请求-响应机制。当完成时,用`close`关闭套接字。
|
30天前
|
缓存 网络协议 数据库连接
【底层服务/编程功底系列】「网络通信体系」深入探索和分析TCP协议的运输连接管理的核心原理和技术要点
【底层服务/编程功底系列】「网络通信体系」深入探索和分析TCP协议的运输连接管理的核心原理和技术要点
24 0
|
1月前
|
域名解析 网络协议 关系型数据库
tcp和udp的区别是什么
TCP和UDP是互联网协议中的传输层协议。TCP是面向连接的,通过三次握手建立可靠连接,提供数据顺序和可靠性保证,适用于HTTP、FTP等需要保证数据完整性的应用。UDP则是无连接的,数据报独立发送,传输速度快但不保证可靠性,常用于实时通信、流媒体和DNS解析等对速度要求高的场景。根据应用需求选择合适的协议至关重要。
tcp和udp的区别是什么
|
1月前
|
网络协议 网络性能优化
认识TCP和UDP的区别
重排机制:由于UDP数据包可能因网络原因而发生乱序,因此在应用层需要对接收到的数据包进行排序。
31 4
|
2天前
|
网络协议 安全 网络性能优化
CCNA 200-301系列:TCP和UDP简介
【4月更文挑战第21天】
14 8
|
2天前
|
缓存 网络协议 安全
TCP和UDP 传输层协议的区别
TCP协议全称是传输控制协议是一种面向连接的、可靠的、基于字节流的传输层通信协议。
7 2
|
1月前
|
网络协议 网络性能优化
网络面试题:TCP和UDP的区别
网络面试题:TCP和UDP的区别
25 0