rpc和http的区别

grpc和http的区别

协议层面

  • http是应用层协议,每次携带大量头部字段,包括connection、host、user-agent、cookie等
  • rpc通常用自定义二进制格式,头部极小,具体看 gRPC 数据包传输格式解析

序列化层面

  • http常用json,字段名重复、解析慢
  • rpc常用protobuf,只传字段编号+值,体积小5-10倍,解析快10倍

连接层面

  • http/1.1 keep-alive可以复用连接,但是串行化,有队头阻塞的问题
  • grpc用http/2,支持tcp长连接+多路复用(一条连接并发多个请求)

对比

复制代码
性能对比(同一个请求):

HTTP+JSON:
  请求: POST /api/users/getUser HTTP/1.1
        Host: user-service
        Content-Type: application/json
        Content-Length: 16
        Cookie: session=xxx
        
        {"userId": 123}
  
  请求大小: ~200字节(头部占80%!)
  序列化: JSON.stringify → O(N)字符处理
  
HTTP/2+gRPC+Protobuf:
	HTTP/2 DATA Frame
	  9B Frame Header
	    Length: 3B
	    Type: 1B
	    Flags: 1B
	    R + Stream Identifier: 4B
	
	  Payload:
	    gRPC Message
	      Compressed Flag: 1B
	      Message Length: 4B
	      Protobuf Body: N Bytes
  
  请求大小: ~15字节(含HTTP/2帧头)
  序列化: protobuf编码 → O(1)单字段,整体O(N)但极快
  
  性能差距:
    序列化速度: Protobuf比JSON快5-10x
    数据体积: Protobuf比JSON小3-5x
    网络延迟: 减少60-80%
    QPS: gRPC比HTTP+JSON高2-5x(同等硬件)

HTTP/2 多路复用:
  HTTP/1.1: 请求1发 → 等响应1 → 请求2发(队头阻塞)
  HTTP/2:   请求1发 → 请求2发 → 请求3发 → 响应乱序到达
            (stream ID区分,同一TCP连接)
  → gRPC天然基于HTTP/2
相关推荐
江华森5 小时前
TDengine 时序数据库深度学习笔记
笔记·时序数据库·tdengine
路人蛃5 小时前
【深入理解计算机系统】第二章第一节(信息存储)笔记
服务器·网络·笔记·计算机网络·系统架构
lunzi_08265 小时前
《图解HTTP》--第5章-与HTTP协作的Web服务器
服务器·前端·http
imDwAaY5 小时前
机器学习入门:从感知机到逻辑回归,理解线性分类器与Softmax CS188 Note20 学习笔记
人工智能·笔记·python·学习·机器学习·逻辑回归
chushiyunen5 小时前
json-rpc笔记
笔记·rpc·json
诸葛思颖5 小时前
论文阅读笔记——NetLLM :当LLM遇上网络管理
论文阅读·笔记
NULL指向我6 小时前
TMS320F28379D笔记3:CPU定时器+SCi串口通信+micro_print
笔记
虹科数字化与AR6 小时前
从传统检测到AR赋能:某汽车零部件厂商的转型之路
经验分享·twyn
http阿拉丁神猫7 小时前
TCP、IPv4和IPv6解读
运维·网络协议·tcp/ip
xian_wwq7 小时前
【学习笔记】提示词注入完全指南:五种变体,一套防御体系
笔记·学习·ai安全