news 2026/6/23 4:38:08

有了TCP为什么还需要HTTP?再用RPC?这次彻底讲明白了

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
有了TCP为什么还需要HTTP?再用RPC?这次彻底讲明白了

有了TCP为什么还需要HTTP?再用RPC?这次彻底讲明白了!

网络协议栈就像盖房子:TCP 是地基(传输层),提供可靠的数据传输;HTTP 是标准户型(应用层),定义了浏览器和服务器怎么“对话”;RPC(远程过程调用)则是定制别墅,专为服务间高效通信设计。很多人纠结“TCP 已经可靠了,为什么层层叠加?”其实这是分层设计的精髓:每层解决特定问题,避免一层包打天下。

1. TCP 是什么?为什么不够用?

TCP(Transmission Control Protocol)是传输层协议,基于 IP(网络层),主要负责:

  • 可靠传输:三次握手建立连接、序号确认、超时重传、流量控制、拥塞控制。
  • 字节流:数据像水流一样有序、无边界发送(无消息概念)。

但 TCP 只是“快递服务”:它保证包裹(数据)可靠送到,但不关心包裹里是什么、怎么拆。直接用 TCP 写应用,你得自己定义:

  • 请求/响应格式
  • 方法名、参数编码
  • 错误处理、认证等

太原始了!就像寄信只写地址,不写信的内容格式——收信人看不懂。

2. 为什么需要 HTTP?(应用层标准协议)

HTTP(HyperText Transfer Protocol)构建在 TCP 之上,专为Web设计:

  • 请求-响应模型:客户端发 Request(方法+路径+头+体),服务器回 Response(状态码+头+体)。
  • 无状态:每个请求独立(HTTP/1.1 支持 Keep-Alive 复用连接)。
  • 文本格式:易读、易调试(头如 Content-Type、Cookie、Cache-Control)。
  • 标准丰富:GET/POST/PUT/DELETE、缓存、重定向、认证、HTTPS 等。

HTTP 让全球浏览器和服务器统一“语言”:你访问网站,不用管后端是什么语言,都能正常显示页面、提交表单。

没有 HTTP,直接用 TCP 访问网页?不可能——你得自己解析 HTML、处理 Cookie、缓存……浏览器会崩溃。

3. HTTP 够用了,为什么还要 RPC?

HTTP 完美适合浏览器-服务器(B/S)场景,但微服务时代,服务间调用(内部通信)有新需求:

  • 性能要求高:HTTP 文本头大、解析慢(JSON/XML)。
  • 类型安全:想直接调用函数,像本地一样(带参数类型、返回对象)。
  • 双向流:需要实时推送(如聊天、流式响应)。
  • 内部高效:不需要浏览器兼容、无状态开销。

RPC(Remote Procedure Call)就是为此而生:让远程调用像本地函数调用一样简单。

  • 常见 RPC:gRPC(Google,开源王者)、Dubbo(阿里)、Thrift(Facebook)。
  • 核心优势
    • 二进制协议(Protobuf):体积小、解析快(比 JSON 快 5-10 倍)。
    • 支持流式(Streaming):单向/双向/服务器流。
    • 代码生成:.proto 文件自动生成客户端/服务端 stub。
    • 基于 HTTP/2:多路复用、头压缩(解决 HTTP/1.1 队头阻塞)。
对比表格:一目了然
维度TCPHTTP (REST/JSON)RPC (gRPC/Dubbo)适用场景
层级传输层应用层应用层-
数据格式字节流文本(头+JSON/XML)二进制(Protobuf)RPC 体积小、快
性能可靠传输基础中等(头大、解析慢)高(HTTP/2 + 二进制)微服务内部首选 RPC
易用性原始,需要自定协议易调试、浏览器友好代码生成、类型安全HTTP 适合对外 API
流式支持有限(Chunked)强大(双向流)实时场景用 RPC
标准性底层标准Web 通用标准框架特定(但 gRPC 流行)HTTP 跨语言/平台最广
总结:为什么层层叠加?
  • TCP:解决可靠传输(底层必须)。
  • HTTP:解决 Web 资源访问标准化(浏览器时代王者)。
  • RPC:解决微服务高效内部调用(云原生时代王者)。

现代系统往往混合用:对外 API 用 HTTP/REST(易集成、文档 Swagger),内部微服务用 gRPC(高性能)。这次彻底明白了吧?TCP 是“路”,HTTP 是“交通规则”,RPC 是“高铁”——各司其职,缺一不可😂

有疑问欢迎追问,比如 gRPC 具体怎么用?下一个话题:REST vs GraphQL?

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 21:20:41

FlashAttention终极指南:突破大模型训练内存瓶颈的完整教程

FlashAttention终极指南:突破大模型训练内存瓶颈的完整教程 【免费下载链接】flash-attention Fast and memory-efficient exact attention 项目地址: https://gitcode.com/GitHub_Trending/fl/flash-attention 你是否在训练大型语言模型时频繁遭遇"显存…

作者头像 李华
网站建设 2026/6/23 20:39:43

冒泡排序 ~ 背下来的 哭

#include <stdio.h> int main() { int i,j,temp;int arr[10]{2,9,3,8,4,7,5,6,0,1};for(i0;i<9;i){for(j0;j<9-i;j){if(arr[j]>arr[j1]){temparr[j];arr[j]arr[j1];arr[j1]temp;}}}for(i0;i<10;i){printf("%d",arr[i]);}return 0; }

作者头像 李华
网站建设 2026/6/22 21:48:57

手把手教你学Simulink——机器人轨迹跟踪场景实例:基于Simulink的永磁同步电机关节空间直线轨迹跟踪控制仿真

目录 手把手教你学Simulink——机器人轨迹跟踪场景实例&#xff1a;基于Simulink的永磁同步电机关节空间直线轨迹跟踪控制仿真 一、引言&#xff1a;从“能动”到“精准动”——轨迹跟踪是机器人智能运动的核心 二、系统架构与控制策略 1. 整体控制框图 2. 关节空间直线轨迹…

作者头像 李华
网站建设 2026/6/23 19:37:29

盈富宝典 通达信主图

{}上线:SMA(C,6.5,1); 下线:SMA(C,13.5,1); 上线界:SMA(C,3,1); 下线界:SMA(C,8,1); STICKLINE(上线>下线 , 上线,下线 ,2.5, 0),COLORRED,LINETHICK2; STICKLINE(下线>上线,上线,下线,2.5,0),COLORGREEN,LINETHICK2; DRAWTEXT( CROSS(上线,下线),LOW *0.98,全仓买入 ),C…

作者头像 李华
网站建设 2026/6/22 20:45:32

14、Python在不同场景下的应用与实践

Python在不同场景下的应用与实践 1. 环境与初始化 在Python开发中,涉及到一些特定库的使用。除了 xbmcplugin 、 xbmcgui 和 xbmcaddon 外,其余都是标准Python库,可通过pip从PyPI获取。而XBMC的Python运行时已内置所有组件,无需自行安装。 urllib 和 urllib2 :…

作者头像 李华
网站建设 2026/6/23 19:37:31

X-AnyLabeling 自动数据标注保姆级教程:从安装到格式转换全流程

在计算机视觉项目中&#xff0c;高质量的标注数据是模型训练成功的关键。然而&#xff0c;手动标注不仅耗时费力&#xff0c;还容易出错。幸运的是&#xff0c;随着 AI 技术的发展&#xff0c;自动标注工具正在大幅降低这一门槛。 本文将手把手带你使用 X-AnyLabeling —— 一…

作者头像 李华