面试题: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框架与通用协议的本质差异
相关推荐
非凡大爹4 小时前
实验十 华为路由器和交换机实现RIP 动态路由协议配置实验指导书
运维·网络·计算机网络·华为
Aaswk4 小时前
计算机网络概述
网络·网络协议·tcp/ip·计算机网络·http·dubbo
梦奇不是胖猫4 小时前
[ 计算机网络 | 第四章 ] 网络层 02 网际协议IP
运维·服务器·网络·网络协议·tcp/ip·计算机网络
艾莉丝努力练剑5 小时前
【Linux网络】Linux 网络编程:传输层协议TCP(五)
linux·运维·网络·计算机网络·udp
小小工匠1 天前
计算机网络 - 彻底理解 CIDR、子网掩码与网段划分
计算机网络·子网掩码·cidr·网段划分
Sagittarius_A*2 天前
H3CSE 高性能园区网:SNMP 网络管理协议详解
网络·计算机网络·安全·h3cse
似水এ᭄往昔2 天前
【Linux网络编程】--计算机网络基础
linux·网络·计算机网络
梦奇不是胖猫2 天前
[ 计算机网络 | 第四章 ] 网络层 01 概述
网络·网络协议·计算机网络
艾莉丝努力练剑2 天前
【Linux网络】Linux 网络编程:传输层TCP(二)
linux·运维·服务器·网络·tcp/ip·计算机网络
basketball6163 天前
计算机网络 物理层通信计算知识点总结
计算机网络