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
相关推荐
白小沫1 小时前
TortoiseSVN 的每个菜单功能是什么??
笔记·学习
爱吃苹果的梨叔1 小时前
2026年分布式坐席系统技术指南:从KVM延长到全IP坐席协作
分布式·网络协议·tcp/ip
七七powerful1 小时前
AI+运维提效--SSL 证书监控系统v3.0版本开发完成
网络·网络协议·ssl
叶~小兮1 小时前
K8S-Helm与灰度发布学习笔记
笔记·学习·kubernetes
sheeta19981 小时前
vue_vuex笔记
javascript·vue.js·笔记
Hua-Jay1 小时前
OpenCV联合C++/Qt 学习笔记(十九)----图像分割
c++·笔记·qt·opencv·学习
七爷不在我这里1 小时前
dockerB站笔记
笔记·docker
河阿里1 小时前
WebSocket:从零开始到实战项目
网络·websocket·网络协议
奋斗的小乌龟2 小时前
langchain4j笔记-07-tool
笔记