当前位置: 首页 > news >正文

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&#xff09…...

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)…...

【kafka】Golang实现分布式Masscan任务调度系统

要求: 输出两个程序,一个命令行程序(命令行参数用flag)和一个服务端程序。 命令行程序支持通过命令行参数配置下发IP或IP段、端口、扫描带宽,然后将消息推送到kafka里面。 服务端程序: 从kafka消费者接收…...

VB.net复制Ntag213卡写入UID

本示例使用的发卡器:https://item.taobao.com/item.htm?ftt&id615391857885 一、读取旧Ntag卡的UID和数据 Private Sub Button15_Click(sender As Object, e As EventArgs) Handles Button15.Click轻松读卡技术支持:网站:Dim i, j As IntegerDim cardidhex, …...

Spring Boot 实现流式响应(兼容 2.7.x)

在实际开发中,我们可能会遇到一些流式数据处理的场景,比如接收来自上游接口的 Server-Sent Events(SSE) 或 流式 JSON 内容,并将其原样中转给前端页面或客户端。这种情况下,传统的 RestTemplate 缓存机制会…...

智慧工地云平台源码,基于微服务架构+Java+Spring Cloud +UniApp +MySql

智慧工地管理云平台系统,智慧工地全套源码,java版智慧工地源码,支持PC端、大屏端、移动端。 智慧工地聚焦建筑行业的市场需求,提供“平台网络终端”的整体解决方案,提供劳务管理、视频管理、智能监测、绿色施工、安全管…...

Keil 中设置 STM32 Flash 和 RAM 地址详解

文章目录 Keil 中设置 STM32 Flash 和 RAM 地址详解一、Flash 和 RAM 配置界面(Target 选项卡)1. IROM1(用于配置 Flash)2. IRAM1(用于配置 RAM)二、链接器设置界面(Linker 选项卡)1. 勾选“Use Memory Layout from Target Dialog”2. 查看链接器参数(如果没有勾选上面…...

【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分

一、项目背景回顾 前五弹完成了Json-Rpc协议解析、请求处理、客户端调用等基础模块搭建。 本弹重点聚焦于服务端的模块划分与架构设计,提升代码结构的可维护性与扩展性。 二、服务端模块设计目标 高内聚低耦合:各模块职责清晰,便于独立开发…...

Selenium常用函数介绍

目录 一,元素定位 1.1 cssSeector 1.2 xpath 二,操作测试对象 三,窗口 3.1 案例 3.2 窗口切换 3.3 窗口大小 3.4 屏幕截图 3.5 关闭窗口 四,弹窗 五,等待 六,导航 七,文件上传 …...

Golang——7、包与接口详解

包与接口详解 1、Golang包详解1.1、Golang中包的定义和介绍1.2、Golang包管理工具go mod1.3、Golang中自定义包1.4、Golang中使用第三包1.5、init函数 2、接口详解2.1、接口的定义2.2、空接口2.3、类型断言2.4、结构体值接收者和指针接收者实现接口的区别2.5、一个结构体实现多…...

LCTF液晶可调谐滤波器在多光谱相机捕捉无人机目标检测中的作用

中达瑞和自2005年成立以来,一直在光谱成像领域深度钻研和发展,始终致力于研发高性能、高可靠性的光谱成像相机,为科研院校提供更优的产品和服务。在《低空背景下无人机目标的光谱特征研究及目标检测应用》这篇论文中提到中达瑞和 LCTF 作为多…...

Mysql故障排插与环境优化

前置知识点 最上层是一些客户端和连接服务,包含本 sock 通信和大多数jiyukehuduan/服务端工具实现的TCP/IP通信。主要完成一些简介处理、授权认证、及相关的安全方案等。在该层上引入了线程池的概念,为通过安全认证接入的客户端提供线程。同样在该层上可…...