TCP/IP原理详细解析
前言
TCP/IP是一种面向连接,可靠的传输,传输数据大小无限制的。通常情况下,系统与系统之间的http连接需要三次握手和四次挥手,这个执行过程会产生等待时间。这方面在日常开发时需要注意一下。
TCP/IP 是互联网的核心协议族,定义了数据如何在网络中进行传输、路由和接收。其设计遵循分层模型(四层或五层),各层独立工作,通过协议协同实现端到端通信。以下章节是其核心原理的逐层解析。
一、TCP/IP 分层模型
| 分层 | 核心功能 | 典型协议 |
|---|---|---|
| 应用层 | 提供用户接口和应用程序服务 | HTTP、FTP、DNS、SMTP、MQTT |
| 传输层 | 提供端到端的数据传输控制 | TCP(可靠)、UDP(不可靠) |
| 网络层 | 负责数据包的路由和寻址 | IP、ICMP、ARP、OSPF、BGP |
| 链路层 | 管理物理介质上的数据帧传输 | Ethernet、Wi-Fi(802.11)、PPP |
二、网络层(IP 协议)
1. IP 协议的核心功能
- 寻址:通过 IP 地址(IPv4 32位,IPv6 128位)唯一标识网络中的设备。
- 路由:根据路由表选择最佳路径,将数据包从源主机传递到目标主机。
- 分片与重组:根据 MTU(最大传输单元) 拆分大数据包,接收端重组。
2. IP 数据包格式
总体上可分为控制信息,与数据体,控制信息包括原地址、目的地址。 首部校验和是对数据进行校验,以保证数据的可靠性。
| 版本 (4) | 首部长度 (4) | 服务类型 (8) | 总长度 (16) |
| 标识 (16) | 标志 (3) | 片偏移 (13) |
| 生存时间 TTL (8) | 协议 (8) | 首部校验和 (16) |
| 源 IP 地址 (32) |
| 目标 IP 地址 (32) |
| 选项(可选) |
| 数据(Payload) |
- 关键字段:
- TTL(Time To Live):每经过一个路由器减1,防止数据包无限循环。
- 协议字段:标识上层协议(如 TCP=6,UDP=17)。
3. 路由机制
- 静态路由:手动配置路由表。
- 动态路由协议:
- 内部网关协议(IGP):如 OSPF(基于链路状态)、RIP(基于距离向量)。
- 外部网关协议(EGP):如 BGP(用于跨自治系统路由)。
三、传输层(TCP/UDP)
1. TCP(传输控制协议)
- 核心特性:
- 面向连接:通过三次握手建立连接,四次挥手释放连接。
- 可靠传输:通过序列号、确认应答、超时重传保证数据完整。
- 流量控制:通过滑动窗口机制动态调整发送速率。
- 拥塞控制:通过慢启动、拥塞避免、快重传、快恢复算法避免网络过载。
TCP 三次握手(建立连接)
1. Client → Server:SYN=1, Seq=x
2. Server → Client:SYN=1, ACK=1, Seq=y, Ack=x+1
3. Client → Server:ACK=1, Seq=x+1, Ack=y+1
- 目的:协商初始序列号,确认双方收发能力。
TCP 四次挥手(释放连接)
1. Client → Server:FIN=1, Seq=u
2. Server → Client:ACK=1, Ack=u+1
3. Server → Client:FIN=1, Seq=v, Ack=u+1
4. Client → Server:ACK=1, Seq=u+1, Ack=v+1
- 目的:确保双方数据均传输完毕,安全关闭连接。
TCP 滑动窗口
- 原理:接收方通过窗口大小告知发送方可接收的数据量,实现动态流量控制。
拥塞控制算法
- 慢启动:初始窗口指数增长,直到阈值或出现丢包。
- 拥塞避免:窗口线性增长,谨慎探测带宽上限。
- 快重传:收到3个重复ACK时立即重传丢失报文。
- 快恢复:丢包后窗口降为阈值,而非重置为1。
2. UDP(用户数据报协议)
- 核心特性:
- 无连接:无需建立连接,直接发送数据。
- 不可靠:不保证数据到达顺序或是否丢失。
- 低开销:首部仅8字节(TCP首部20字节+选项)。
- 适用场景:实时音视频、DNS查询、物联网传感器数据。
四、应用层协议
1. HTTP(超文本传输协议)
- 无状态协议:每次请求独立,依赖 Cookie/Session 维持状态。
- 方法:GET、POST、PUT、DELETE 等。
- 版本演进:
- HTTP/1.1:持久连接、管道化。
- HTTP/2:多路复用、头部压缩。
- HTTP/3:基于 QUIC(UDP),解决队头阻塞。
2. DNS(域名解析协议)
- 功能:将域名(如
www.example.com)解析为 IP 地址。 - 查询过程:递归查询(客户端→本地DNS→根DNS→权威DNS)。
3. MQTT(物联网消息协议)
- 特点:轻量级、发布-订阅模式,适合低带宽、高延迟环境。
五、关键辅助协议
1. ARP(地址解析协议)
- 功能:通过 IP 地址查询 MAC 地址。
- 过程:广播 ARP 请求,目标主机单播回复。
2. ICMP(互联网控制消息协议)
- 功能:传递网络错误信息(如
ping基于 ICMP Echo Request/Reply)。 - 典型应用:Traceroute 诊断网络路径。
六、数据封装与分用
1. 数据封装流程(发送端)
应用层数据 → 添加TCP/UDP首部 → 添加IP首部 → 添加帧头帧尾 → 物理比特流
2. 数据分用流程(接收端)
物理比特流 → 解析帧头 → 解析IP首部 → 解析TCP/UDP首部 → 交付应用层
七、TCP/IP 的典型问题与优化
1. 粘包与拆包
- 原因:TCP 是字节流协议,无消息边界。
- 解决方案:
- 定长消息。
- 分隔符(如
\n)。 - 消息头声明长度(如 HTTP 的
Content-Length)。
2. NAT(网络地址转换)
- 功能:将私有 IP 映射为公网 IP,解决 IPv4 地址不足。
- 类型:静态 NAT、动态 NAT、PAT(端口复用)。
3. 性能优化
- TCP 优化:调整窗口大小、启用快速打开(TFO)。
- HTTP 优化:启用持久连接、压缩、缓存。
总结:TCP/IP 的设计哲学
- 分层解耦:各层独立演进,互不影响(如 HTTP/3 替换 TCP 为 QUIC)。
- 端到端原则:复杂逻辑尽量放在终端,保持网络核心简单高效。
- 鲁棒性:通过冗余(如多路径路由)、容错(如重传)保障可靠性。
理解 TCP/IP 协议原理,是掌握网络编程、运维和架构设计的基础。
相关文章:
TCP/IP原理详细解析
前言 TCP/IP是一种面向连接,可靠的传输,传输数据大小无限制的。通常情况下,系统与系统之间的http连接需要三次握手和四次挥手,这个执行过程会产生等待时间。这方面在日常开发时需要注意一下。 TCP/IP 是互联网的核心协议族&…...
Microsof Visual Studio Code 安装教程(中文设置)
VS Code 是一个免费的代码编辑器,可在 macOS、Linux 和 Windows作系统上运行。启动和运行 VS Code 既快速又简单。VS Code(全称 Visual Studio Code)是一款由Microsoft 推出的免费、开源、跨平台的代码编辑器,拥有强大的功能和灵活…...
python爬虫:Android自动化工具Auto.js的详细使用
更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 1. Auto.js 简介2. 安装与配置2.1 安装 Auto.js2.2 安装 Python 环境2.3 安装 ADB 工具3. Python 与 Auto.js 结合3.1 通过 ADB 执行 Auto.js 脚本3.2 通过 Python 控制 Auto.js3.3 通过 Python 与 Auto.js 交互4. 常用…...
Unity DOTS从入门到精通之 自定义Authoring类
文章目录 前言安装 DOTS 包什么是Authoring1. 实体组件2. Authoring类 前言 DOTS(面向数据的技术堆栈)是一套由 Unity 提供支持的技术,用于提供高性能游戏开发解决方案,特别适合需要处理大量数据的游戏,例如大型开放世…...
linux 软件安装(上)
一、基础环境准备 1.1、安装VM 1.2、在VM上导入linux iso镜像,装好linux系统 华为centos镜像下载地址 https://mirrors.huaweicloud.com/centos/ https://mirrors.huaweicloud.com/centos/7.9.2009/isos/x86_64/ 网易centos镜像下载地址 htt…...
php虚拟站点提示No input file specified时的问题及权限处理方法
访问站点,提示如下 No input file specified. 可能是文件权限有问题,也可能是“.user.ini”文件路径没有配置对,最简单的办法就是直接将它删除掉,还有就是将它设置正确 #配置成自己服务器上正确的路径 open_basedir/mnt/qiy/te…...
【江协科技STM32】ADC数模转换器-学习笔记
ADC简介 ADC(Analog-Digital Converter)模拟-数字转换器ADC可以将引脚上连续变化的模拟电压转换为内存中存储的数字变量,建立模拟电路到数字电路的桥梁,ADC是一种将连续的模拟信号转换为离散的数字信号的设备或模块12位逐次逼近型…...
QT系列教程(20) Qt 项目视图便捷类
视频连接 https://www.bilibili.com/video/BV1XY41127t3/?vd_source8be9e83424c2ed2c9b2a3ed1d01385e9 Qt项目视图便捷类 Qt项目视图提供了一些便捷类,包括QListWidget, QTableWidget, QTreeWidget等。我们分别介绍这几个便捷类。 我们先创建一个Qt …...
git worktree的使用
git worktree 是 Git 提供的一个强大功能,允许你在同一个仓库中同时创建多个工作目录,每个目录对应一个分支,从而实现并行开发。以下是 git worktree 的常用命令和使用方法: 1. 创建新的工作目录(Worktree)…...
Spring Boot+RabbitMQ+Canal 解决数据一致性
目录大纲 一、环境配置1.1 docker-compose.yml 配置1.2 docker-compose 常用命令1.3 镜像服务启动状态 二、MySQL binlog 配置2.1 docker-compose command 配置 binlog2.2 创建canal用户,以及查看是否开启binlog 三、canal 相关配置文件3.1 canal.properties 完整文…...
Java高频面试之集合-08
hello啊,各位观众姥爷们!!!本baby今天来报道了!哈哈哈哈哈嗝🐶 面试官:详细说说CopyOnWriteArrayList CopyOnWriteArrayList 详解 CopyOnWriteArrayList 是 Java 并发包(java.util…...
C#实现高性能异步文件下载器(支持进度显示/断点续传)
一、应用场景分析 异步文件下载器用处很大,当我们需要实现以下功能时可以用的上: 大文件下载(如4K视频/安装包) 避免UI线程阻塞,保证界面流畅响应多任务并行下载 支持同时下载多个文件,提升带宽利用率后台…...
【数据分析】转录组基因表达的KEGG通路富集分析教程
禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍差异分析(limma)KEGG富集分析(enrichKEGG)可视化加载R包数据下载导入数据基因差异分析火山图KEGG通路富集分析可视化通路结果另一个案例总结系统信息参考介绍 KEGG富集分析,可…...
【由技及道】API契约的量子纠缠术:响应封装的十一维通信协议(全局的返回结果封装)【人工智障AI2077的开发日志012】
摘要:在API通信的量子混沌中,30种返回格式如同平行宇宙的物理定律相互碰撞。本文构建的十一维通信协议,通过时空锚点(ApiResult)、量子过滤器(ResponseWrapper)和湮灭防护罩(Jackson…...
STM32 ——系统架构
3个被动单元 SRAM 存储程序运行时用到的变量 Flash(内部闪存存储器) 存储下载的程序 程序执行时用到的常量 桥接1和桥接2 AHB到APB的桥(AHBtoAPBx) 桥1 通过APB2总线连接到APB2上的外设。 高速外设,最高72MHz。 桥2 通过…...
算法 之 树形dp 树的中心、重心
文章目录 重心实践题目小红的陡峭值 在树的算法中,求解树的中心和重心是一类十分重要的算法 求解树的重心 树的重心的定义:重心是树中的一个节点,如果将这个点删除后,剩余各个连通块中点数的最大值最小,那么这个节点…...
如何利用 Excel 表格实现精准文件批量重命名教程
在处理大量文件时,有时需要根据特定规则对文件名进行调整。如果您的文件名和新名称之间存在一对多的关系,并且这种关系可以通过 Excel 表格来管理,那么使用“简鹿文件批量重命名”软件中的“匹配对应名称命名”功能将是一个高效的选择。接下来…...
ACE协议学习1
在多核系统或复杂SoC(System on Chip)中,不同处理器核心或IP(Intellectual Property)模块之间需要保持数据的一致性。常用的是ACE协议or CHI。 先对ACE协议进行学习 ACE协议(Advanced Microcontroller Bu…...
【实战ES】实战 Elasticsearch:快速上手与深度实践-5.1.1热点分片识别与均衡策略
👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 5.1.1 Filebeat Logstash ES Kibana 全链路配置实1. 架构设计与组件选型1.1 技术栈对比分析1.2 硬件配置推荐 2. Filebeat 高级配置2.1 多输入源配置2.2 性能优化参数 3.…...
Kubernetes 的正式安装
1.基础的网络结构说明 软件路由器 ikuai 当然同一个仅主机模式 相当于在 同一个我们所谓的广播域内 所以相当于它们的几张网卡 是被连接起来的 为了防止出现问题 我们可以把第二块网卡临时关闭一下 2.准备路由器 ikuai 爱快 iKuai-商业场景网络解决方案提供商 (ikuai8.com)…...
模型参数、模型存储精度、参数与显存
模型参数量衡量单位 M:百万(Million) B:十亿(Billion) 1 B 1000 M 1B 1000M 1B1000M 参数存储精度 模型参数是固定的,但是一个参数所表示多少字节不一定,需要看这个参数以什么…...
阿里云ACP云计算备考笔记 (5)——弹性伸缩
目录 第一章 概述 第二章 弹性伸缩简介 1、弹性伸缩 2、垂直伸缩 3、优势 4、应用场景 ① 无规律的业务量波动 ② 有规律的业务量波动 ③ 无明显业务量波动 ④ 混合型业务 ⑤ 消息通知 ⑥ 生命周期挂钩 ⑦ 自定义方式 ⑧ 滚的升级 5、使用限制 第三章 主要定义 …...
【SpringBoot】100、SpringBoot中使用自定义注解+AOP实现参数自动解密
在实际项目中,用户注册、登录、修改密码等操作,都涉及到参数传输安全问题。所以我们需要在前端对账户、密码等敏感信息加密传输,在后端接收到数据后能自动解密。 1、引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId...
【第二十一章 SDIO接口(SDIO)】
第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...
系统设计 --- MongoDB亿级数据查询优化策略
系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log,共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题,不能使用ELK只能使用…...
【ROS】Nav2源码之nav2_behavior_tree-行为树节点列表
1、行为树节点分类 在 Nav2(Navigation2)的行为树框架中,行为树节点插件按照功能分为 Action(动作节点)、Condition(条件节点)、Control(控制节点) 和 Decorator(装饰节点) 四类。 1.1 动作节点 Action 执行具体的机器人操作或任务,直接与硬件、传感器或外部系统…...
大模型多显卡多服务器并行计算方法与实践指南
一、分布式训练概述 大规模语言模型的训练通常需要分布式计算技术,以解决单机资源不足的问题。分布式训练主要分为两种模式: 数据并行:将数据分片到不同设备,每个设备拥有完整的模型副本 模型并行:将模型分割到不同设备,每个设备处理部分模型计算 现代大模型训练通常结合…...
什么?连接服务器也能可视化显示界面?:基于X11 Forwarding + CentOS + MobaXterm实战指南
文章目录 什么是X11?环境准备实战步骤1️⃣ 服务器端配置(CentOS)2️⃣ 客户端配置(MobaXterm)3️⃣ 验证X11 Forwarding4️⃣ 运行自定义GUI程序(Python示例)5️⃣ 成功效果