TCP与UDP协议

一、TCP与UDP对比:

传输层定义了主机应用程序之间端到端的连通性。

传输层中最为常见的两个协议分别是:

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

用户数据包协议UDP(User Datagram Protocol)

TCP位于TCP/IP模型的传输层,它是一种面向连接的端到端协议。

TCP作为传输控制协议,可以为主机提供可靠的数据传输。
UDP是一种面向无连接的传输层协议,传输可靠性没有保证。

UDP将数据从源端发送到目的端时,无需事先建立连接。

相比于TCP,UDP的传输效率更高、开销更小,但是无法保障数据传输的可靠性。

UDP不提供重传机制,占用资源小,处理效率高。

一些时延敏感的流量,如语音、视频等,通常使用UDP作为传输层协议。

二、TCP/UDP+端口号=服务

TCP允许一个主机同时运行多个应用进程。

每台主机可以拥有多个应用端口,每对端口号、源和目标IP地址的组合唯一地标识了一个会话。

端口分为知名端口和动态端口。

有些网络服务会使用固定的端口,这类端口称为知名端口,端口号范围为0-1023。如FTP、HTTP、Telnet、SNMP服务均使用知名端口。

动态端口号范围从1024到65535,这些端口号一般不固定分配给某个服务,也就是说许多服务都可以使用这些端口。

只要运行的程序向系统提出访问网络的申请,那么系统就可以从这些端口号中分配一个供该程序使用。

协议 端口号

FTP 21、20

HTTP 80

Telnet 23

SMTP 25

三、TCP的建立和断开:

TCP是一种可靠的,面向连接的全双工传输层协议。

TCP连接的建立是一个三次握手的过程。

1、主机A(通常也称为客户端)发送一个标识了SYN的数据段,表示期望与服务器A建立连接,此数据段的序列号(seq)为a。

2、服务器A回复标识了SYN+ACK的数据段,此数据段的序列号(seq)为b,确认序列号为主机A的序列号加1(a+1),以此作为对主机A的SYN报文的确认。

3、主机A发送一个标识了ACK的数据段,此数据段的序列号(seq)为a+1,确认序列号为服务器A的序列号加1(b+1),以此作为对服务器A的SYN报文的确认。

TCP连接的终止则要经过四次挥手。

1、主机A想终止连接,于是发送一个标识了FIN,ACK的数据段,序列号为a,确认序列号为b。

2、服务器A回应一个标识了ACK的数据段,序列号为b,确认序号为a+1,作为对主机A的FIN报文的确认。

3、服务器A想终止连接,于是向主机A发送一个标识了FIN,ACK的数据段,序列号为b,确认序列号为a+1。

4、主机A回应一个标识了ACK的数据段,序列号为a+1,确认序号为b+1,作为对服务器A的FIN报文的确认。

相关推荐
Sylvan Ding5 小时前
Clawdbot (OpenClaw/Moltbot) 内网穿透部署方案(安全有效-Linux-2026.01.30)
linux·运维·安全·tailscale·clawdbot·moltbot·openclaw
汤愈韬5 小时前
DHCP Server服务器拒绝攻击、DHCP Server服务器拒绝攻击防范、端口安全
网络协议·网络安全·security
cyber_两只龙宝5 小时前
haproxy--实现能7层负载均衡、基于cookie会话保持、状态页监控的高性能web服务器集群
linux·运维·负载均衡·监控·haproxy·会话保持·高性能集群
小苏兮5 小时前
【把Linux“聊”明白】命令行参数与环境变量
linux·运维·服务器·学习
大闲在人5 小时前
使用有向莱顿算法进行供应链/物料流转网络的集群划分
网络·算法
lcx_defender6 小时前
【Docker】Docker部署运行Seata
运维·docker·容器
cuijiecheng20186 小时前
Linux下inih库的使用
linux·运维·服务器
GIS瞧葩菜6 小时前
entity几何体轴编辑(沿 Z 轴平移)完整流程拆解
linux·运维·ubuntu
一起养小猫8 小时前
Flutter for OpenHarmony 实战:打造天气预报应用
开发语言·网络·jvm·数据库·flutter·harmonyos