gRPC主要特点

核心功能

  • 提供C/S架构中的通信能力(包括流式传输),使用了比 JSON、XML 更优的对象序列化协议 protobuf。

    基于HTTP/2,支持一元 RPC、服务器流式 RPC 、客户端流式 RPC、双向流式 RPC;

    • 双向流式 RPC,双方使用读写流发送一系列消息。两个流独立运行,因此客户端和服务器可以按任意顺序进行读写:例如,服务器可以等待接收所有客户端消息后再写入响应,也可以交替读取消息然后写入消息,或者采用其他读写组合。每个流中的消息顺序都会保留。

      proto 复制代码
      rpc BidiHello(stream HelloRequest) returns (stream HelloResponse);
  • gRPC-Web功能:支持浏览器与gRPC服务端进行通信(只需额外配置Envoy proxy即可完成gRPC-Web到gRPC的转换)

  • 可插拔设计(Pluggable):支持负载平衡、链路追踪、健康检查和身份验证

官网原话(https://grpc.io/about/#core-features-that-make-it-awesome)

  • Idiomatic client libraries in 11 languages
  • Highly efficient on wire and with a simple service definition framework
  • Bi-directional streaming with http/2 based transport
  • Pluggable auth, tracing, load balancing and health checking

IDL

Interface Definition Language

使用protocol buffer作为IDL.

ProtoBuf在gRPC的框架中主要有三个作用:

  • 定义数据结构
  • 定义服务接口
  • 通过序列化和反序列化,提升传输效率

可插拔设计(Pluggable)

(尚未书写)

负载均衡

官网:https://grpc.io/blog/grpc-load-balancing/#load-balancing-options

介绍了两类常见的负载均衡方式:

对于不同业务场景,推荐了不同的方式:https://grpc.io/blog/grpc-load-balancing/#recommendations-and-best-practices。

gRPC 目前支持自己的grpc-LB协议 ,用于后备负载平衡(lookaside-load-balancing)。但是,流行的Envoy代理使用xDS API 进行多种类型的配置,包括负载平衡,并且该 API 正在发展成为一种标准,将用于配置各种数据平面软件。为了顺应这一行业趋势,gRPC 将从其原始的 grpc-LB 协议转移到新的 xDS 协议。

gRPC 提供了许多 LB 策略。最值得注意的是pick_first(默认,首个符合,即无配置)、round_robin(顺序分配)和 grpclb(已废弃)。还有许多其他 LB 策略来支持 xDS,尽管它们目前无法直接配置。

workflow

相关推荐
摇滚侠6 分钟前
HTTP 和 HTTPS 有什么区别?加密原理和证书
网络协议·http·https
墨风如雪28 分钟前
手把手教你测试VPS网络质量:详解测试IP与LookingGlass用法 (以RackNerd洛杉矶DC02为例)
后端·网络协议
Python_Study20251 小时前
企业级数据采集系统选型指南:从技术架构到实战解决方案剖析
架构
不吃香菜5671 小时前
实现WebSocket实时定位的方法(物流,租车,代驾,商城)
websocket·网络协议·信息与通信
roman_日积跬步-终至千里1 小时前
【大数据架构:架构思想基础】Google三篇论文开启大数据处理序章:(数据存储)分布式架构、(数据计算)并行计算、(数据管理)分片存储
大数据·分布式·架构
小股虫2 小时前
数据库外科手术:一份拖垮系统的报表,如何倒逼架构演进
数据库·微服务·设计模式·架构·方法论
乾元2 小时前
网络切片的自动化配置与 SLA 保证——5G / 专网场景中,从“逻辑隔离”到“可验证承诺”的工程实现
运维·开发语言·网络·人工智能·网络协议·重构
神算大模型APi--天枢6462 小时前
自主算力筑基,垂域模型破局:国产硬件架构下的行业大模型训练与微调服务实践
大数据·人工智能·科技·架构·硬件架构
国科安芯2 小时前
低轨卫星姿态调整系统的抗辐照设计与工程实现
运维·网络·嵌入式硬件·安全·架构·安全威胁分析·risc-v
Learn Forever3 小时前
【智能体】AI Agent 记忆系统:从短期到长期的技术架构与实践指南
人工智能·架构