TCP、TLS、HTTP、HTTPS、MQTT、MQTTS几种网络协议的对比与解释

目录

核心层级逻辑

  • TCP 是传输层的 "可靠运输通道",负责把数据从 A 点稳定送到 B 点;
  • TLS 是给 "运输通道" 加的 "安全锁",负责加密数据、验证身份;
  • HTTP/HTTPS/MQTT 是应用层的 "数据封装格式",定义了数据如何组织、如何交互。

嵌入式开发选型建议

  • 简单调试、小数据量交互 → HTTP + TCP;
  • 敏感数据传输、对接公网云平台 → HTTPS;
  • 海量物联网设备并发通信、低功耗场景 → MQTT/MQTT-S。

一、TCP

全称 Transmission Control Protocol
定义 传输控制协议,一种面向连接、可靠的字节流协议
层级 传输层
特点 三次握手建立连接,四次挥手断开连接;保证数据有序、无丢失、无重复; 拥塞控制、流量控制;开销相对较大
适用场景 1. 需要可靠数据传输的场景(如 OTA 固件升级、文件传输)2. HTTP、HTTPS、MQTT 的底层传输协议
与其它协议的关系 1. 是 HTTP、HTTPS、MQTT 的传输基础 2. 与 UDP 并列,同为传输层核心协议

二、HTTP

全称 HyperText Transfer Protocol
定义 超文本传输协议,一种基于 TCP 的应用层协议
层级 应用层
特点 1. 明文传输,无加密,安全性低 2. 基于请求 - 响应模型 3. 无状态(每次请求独立)4. 端口默认 80
适用场景 1. 设备与服务器的轻量级数据交互(如上报传感器数据) 2. 调试阶段的简单通信
与其它协议的关系 1. 底层基于 TCP 传输 2. HTTPS 是 HTTP 的安全升级版

三、TLS

全称 Transport Layer Security
定义 传输层安全协议,一种提供加密、身份认证的安全协议
层级 会话层 / 表示层
特点 1. 提供数据加密、完整性校验、身份验证2. 前身是 SSL 协议3. 支持双向认证(服务端 + 客户端)4. 可与多种传输层协议结合
适用场景 1. 为 HTTP、TCP 等协议提供安全加密 2. ESP32 设备与云端的安全通信
与其它协议的关系 1. 是 HTTPS、MQTT-S 的安全基础 2. 不独立传输数据,需依附于 TCP 等协议

四、HTTPS

全称 HyperText Transfer Protocol Secure
定义 超文本传输安全协议
层级 应用层
特点 1. = HTTP + TLS/SSL ,HTTP 的安全版本 2. 数据全程加密传输 ,防止窃听、篡改 3. 端口默认 443 4. 需配置证书(自签名 / CA 证书)
适用场景 1. 设备与云端的敏感数据传输(如设备配网、用户信息上报) 2. 对接主流云平台(阿里云、腾讯云)
与其它协议的关系 1. 底层基于 TCP 传输2. 用 TLS 协议对 HTTP 数据加密

五、MQTT

全称 Message Queuing Telemetry Transport
定义 消息队列遥测传输协议,一种基于 TCP 的轻量级发布 - 订阅协议
层级 应用层
特点 1. 基于发布 - 订阅模型(一对多通信) 2. 报文头极小(最小 2 字节),开销极低 3. 支持 QoS 等级(0/1/2),保证不同可靠性需求 4. 支持断线重连、遗嘱消息 5. 端口默认 1883(明文)
适用场景 1. 物联网设备海量并发通信(如传感器网络、智能家居集群)2. 低带宽、高延迟、不稳定网络场景 3. ESP32 作为终端节点接入物联网平台
与其它协议的关系 1. 底层基于 TCP 传输 2. 可与 TLS 结合,升级为MQTT-S(安全版,端口 8883)

六、MQTTS

全称 Message Queuing Telemetry Transport Secure
定义 安全版消息队列遥测传输协议
层级 应用层
特点 1. = MQTT + TLS/SSL 的安全组合 2. 继承 MQTT 的轻量、发布 - 订阅特性 3. 数据加密传输,支持设备证书认证 4. 端口默认 8883
适用场景 1. ESP32 对接 AWS IoT、Azure IoT 等公有云平台 2. 公网环境下的物联网设备海量并发通信 3. 需保障数据安全的场景(如传感器数据上报、远程控制)
与其它协议的关系 底层基于 TCP+TLS,是 MQTT 的安全版本
相关推荐
cur1es7 小时前
【UDP的报文结构】
网络·网络协议·udp·md5
闲人编程7 小时前
使用FastAPI和WebSocket构建高性能实时聊天系统
websocket·网络协议·网络编程·fastapi·持久化·实时聊天·codecapsule
惊讶的猫7 小时前
OpenFeign(声明式HTTP客户端)
网络·网络协议·http·微服务·openfeign
心.c8 小时前
TCP协议深入解析
网络·网络协议·tcp/ip
摇滚侠8 小时前
HTTP 404 - No response body available
网络·网络协议·http
深圳市九鼎创展科技8 小时前
瑞芯微 RK3399 开发板 X3399 评测:高性能 ARM 平台的多面手
linux·arm开发·人工智能·单片机·嵌入式硬件·边缘计算
辰哥单片机设计8 小时前
STM32项目分享:车辆防盗报警系统
stm32·单片机·嵌入式硬件
全栈工程师修炼指南8 小时前
Nginx | stream content 阶段:TCP 协议四层反向代理浅析与实践
运维·网络·网络协议·tcp/ip·nginx
Trouvaille ~8 小时前
【Linux】应用层协议设计实战(一):自定义协议与网络计算器
linux·运维·服务器·网络·c++·http·应用层协议
CSCN新手听安8 小时前
【linux】网络基础(三)TCP服务端网络版本计算器的优化,Json的使用,服务器守护进程化daemon,重谈OSI七层模型
linux·服务器·网络·c++·tcp/ip·json