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
相关推荐
王二端茶倒水4 小时前
宽带无线项目,怎么从一次性交付变成长期运营收入?
网络协议
Goodbye4 小时前
大模型无状态架构:从 HTTP 协议到 Harness AI 工程的深度解析
http
用户2530171996271 天前
第6篇:从技术到产品 — Ghost Proxifier 的设计哲学
网络协议
用户2530171996271 天前
第3篇:注入的艺术 — Ghost Proxifier 核心架构拆解
网络协议
王二端茶倒水2 天前
商业 WiFi 不是免费上网,而是门店数字化的入口
网络协议
LinXunFeng3 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
霜落长河6 天前
抛弃TCP改用UDP,HTTP3怎么了?
http
SM177152118387 天前
NSK紧凑型FA系列丝杠技术详解
经验分享·规格说明书
闪闪发亮的小星星7 天前
高斯光以及高斯光公式解释
笔记