TCP/UDP协议基础知识
1.协议
指的是一组规则
2.分层模型结构
- OSI七层模型:物理层、数据链路层、网络层、传输层、会话层、表示层、应用层
- TCP/IP 四层模型:链路层、网络层、传输层、应用层
- 应用层:HTTP,FTP,NFS,SSH,TELNET
- 传输层:TCP、UDP
- 网络层:IP、ICMP、IGMP
- 链路层:以太网帧协议、ARP
3.以太网协议
- ARP协议:根据IP地址获取MAC地址
- 以太网帧协议:根据MAC地址,完成数据包的传输
4.IP协议
- 版本:IPv4、IPv6
- TTL:(time to live)设置数据包在路由节点上的跳转上限,每经过一个节点数值-1,当减为0后该路由有义务将这个数据包丢弃
- 源IP:32位,4字节
- 目的IP:32位,4字节
- 点分十进制IP:如常见的192.168.1.1
5.UDP
-
全称:用户数据报协议
-
源端口号:16位,最大值65536
-
目的端口号:16位,最大值65536
-
端口号:可以在网络的一台主机上,唯一的标识一个进程
-
IP地址:可以在网络环境中,唯一的标识一台主机
-
IP+COM:可以在网络环境中,唯一的标识一个进程
6.TCP
-
全称:传输控制协议
-
源端口号:16位,最大值65536
-
目的端口号:16位,最大值65536
-
32位序号:数据的标号
-
32位确认序号:ACK应答信号的标号
-
6个标志位:ACK用于应答,FIN用于关闭连接,SYN用于建立连接
-
16位窗口大小:滑动窗口的大小,最大值65536
-
三次握手:
- 主动发起连接请求端,发送SYN标志位,请求建立连接,携带序号、数据字节数(0),滑动窗口大小。
- 被动接受连接请求端,发送ACK标志位,同时携带SYN标志位,携带序号、确认序号、数据字节数(0),滑动窗口大小。
- 主动发起连接请求端,发送ACK标志位,应答服务器连接请求。携带确认序号。
-
四次挥手:
- 主动关闭连接请求端,发送FIN标志位
- 被动关闭连接请求端,应答ACK标志位
- 被动关闭连接请求端,发送FIN标志位
- 主动关闭连接请求端,应答ACK标志位
-
滑动窗口:
发送给连接对端,本端的实时缓冲区大小,保证数据不会丢失。
7.c/s和b/s模型
-
c/s:客户端服务器模型
-
b/s:浏览器服务器模型
-
对比:
c/s b/s 优点 缓存大量数据、协议选择灵活、速度快 安全性好、跨平台、开发工作量小 缺点 安全性差、不跨平台、开发工作量大 不能缓存大量数据、严格遵守HTTP
8.TCP状态时序图
-
主动发起连接请求端:CLOSE状态 → 发送SYN
→ SEND_SYN状态 → 接收ACK、发送SYN
→ SEND_SYN状态 → 发送ACK
→ESTABLISHED状态
-
主动关闭连接请求端:ESTABLISHED状态 → 发送FIN
→ FIN_WAIT1状态 → 接收ACK
→ FIN_WAIT2半关闭状态 → 接收对端发送FIN
→ FIN_WAIT2半关闭状态 → 回发ACK
→ TIME_WAIT(主动关闭方才会经历)状态 → 等2MSL时长
→ CLOSE状态
-
被动接受连接请求端:CLOSE状态(直接进入到监听状态)
→ LISTEN状态 → 接受SYN
→LISTEN状态 → 发送ACK、SYN
→ SYN_RCVD状态 → 接受ACK
→ ESTABLISHED状态
-
被动关闭连接请求端:ESTABLISH状态 → 接受FIN
→ ESTABLISH状态 → 发送ACK
→ CLOSE_WAIT(说明对端处于半关闭状态)状态 → 发送FIN
→ LAST_ACK状态 → 接受ACK
→ CLOSE状态
重点是:ESTABLISH、 FIN_WAIT2、CLOSE_WAIT、TIME_WAIT
-
2MSL时长:
-
保证最后一个ACK能够被对端接收。(等待期间,对端没有收到ACK,对端会再次发送FIN)
-
只会发生在主动请求关闭连接的一端。
-
在ubuntu里大约是40s
-
9.设置端口复用
int opt = 1; //设置端口复用
setsockopt(lfd, SOL_SOCKET, SO_REUSEADDR, (void*)&opt, sizeof(opt));
//返回值成功是0 错误时-1
- 设置了端口复用后就不用再等待2MSL时长来等待释放端口
10.半关闭
-
通信双方中,只有一端关闭通信,对应FIN_WAIT2状态
-
半关闭的实现方法:
close(fd);
int shutdown(int fd, int how);
-
fd:文件描述符
-
how:(对应套接字缓冲区的关闭方式)
SHUT_RD 关读端
SHUT_WR 关写端
SHUT_RDWR 关读写
-