面试题:gRPC与HTTP协议的区别

一、面试问题

请说一下gRPC和HTTP协议有什么区别?

二、核心概念厘清

1. gRPC 本质 :gRPC不是独立通信协议 ,而是Google开源的高性能RPC框架

  • 底层传输:强制基于 HTTP/2.0
  • 默认序列化:Protobuf(二进制)
  • 定位:服务间高性能远程调用

2. HTTP 本质 :通用应用层通信协议,是Web通信基础,面向客户端-服务器通用交互。

三、gRPC 与 HTTP 核心区别对比表

对比维度 gRPC HTTP(RESTful)
本质定位 RPC框架,面向服务间调用 通用应用层协议,面向C/S通信
底层传输 基于 HTTP/2.0,长连接+多路复用 主流 HTTP/1.1,并发需多TCP连接
序列化格式 Protobuf(二进制,体积小、速度快) JSON(文本,可读性高、体积大)
通信模式 支持4种:一元/服务端流/客户端流/双向流 仅支持 请求-响应 单向模式
性能表现 二进制+头部压缩+多路复用,低延迟 文本传输,头部冗余,HTTP/1.1队头阻塞
类型安全 强类型,编译期校验 弱类型,依赖约定
浏览器兼容 原生不支持,需gRPC-Web 全浏览器原生支持
适用场景 微服务内部、高并发、实时通信 前后端、对外API、通用Web服务

四、HTTP/2.0 核心优化(gRPC性能基础)

  • 二进制分帧:替换文本格式,解析更高效
  • 多路复用 :单TCP连接并行传输,解决应用层队头阻塞
  • HPACK头部压缩:减少头部冗余,降低带宽
  • 服务器推送:主动推送资源,无需重复请求
  • 流优先级:核心资源优先传输

重要说明 :HTTP/2.0 仅解决应用层队头阻塞,TCP层仍存在队头阻塞,HTTP/3 基于QUIC彻底解决该问题。

五、标准回答

复制代码
gRPC是基于HTTP/2.0的RPC框架,HTTP是通用应用层协议。
区别主要有四点:
第一,定位与场景:gRPC专注跨语言服务高性能调用,适合微服务、高并发、实时场景;HTTP是通用协议,适合前后端、对外公开API。
第二,底层与性能:gRPC基于HTTP/2.0,多路复用+头部压缩+二进制序列化,延迟低、并发强;HTTP主流用HTTP/1.1+JSON,头部冗余、存在队头阻塞。
第三,通信模式:gRPC支持一元、单向流、双向流四种全双工模式;HTTP仅支持请求-响应。
第四,类型安全:gRPC强类型校验,提前发现错误;HTTP弱类型,依赖文档约定。
补充:HTTP/2解决应用层队头阻塞,TCP层仍阻塞,HTTP/3用QUIC彻底优化。

六、常见认知误区纠正

  • 错误 :gRPC是独立协议,与HTTP并列 → 正确:gRPC基于HTTP/2.0,是框架而非协议
  • 错误 :gRPC使用Protobuf协议 → 正确:Protobuf是序列化格式,传输层是HTTP/2.0
  • 错误 :HTTP/2存在队头阻塞 → 正确:仅TCP层阻塞,应用层已解决
  • 错误 :区别=HTTP/2与HTTP/1区别 → 正确:核心是RPC框架与通用协议的本质差异
相关推荐
未来转换3 小时前
计算机网络基础之IP地址详解
tcp/ip·计算机网络·php
南湖北漠6 小时前
浅谈生活中的规范化品牌代理标准店和精简标准代理店 时间:2026年3月30日(来源网络,原创)
网络·人工智能·计算机网络·其他·生活
zl_dfq7 小时前
计算机网络 之 【https协议】(数字摘要、密钥、数字证书)
网络协议·计算机网络·https
头疼的程序员9 小时前
计算机网络:自顶向下方法(第七版)第七章 学习分享(二)
网络·学习·计算机网络
yueqc11 天前
计算机网络(二):HTTPDNS、IPv6、QUIC
计算机网络·quic·ipv6·httpdns
yueqc11 天前
计算机网络(一):TCP
计算机网络·tcp
CS创新实验室1 天前
《计算机网络》深入学:信道复用技术
计算机网络·信道复用技术
南湖北漠2 天前
听说拍照的人会拿相似的鱼皮豆代替野生鹌鹑蛋拍照(防原创)
网络·人工智能·计算机网络·生活
先跑起来再说2 天前
从原理到实践:彻底搞懂Cookie和Session的区别
计算机网络·http·https