首页 > 其他分享 >Why gRPC ?

Why gRPC ?

时间:2023-11-29 17:12:23浏览次数:37  
标签:Protocol gRPC 支持 IDL HTTP Why Buffers

gRPC(gRPC Remote Procedure Call)是由 Google 开发的开源 RPC 框架,它基于 HTTP/2 标准,使用 Protocol Buffers 作为接口定义语言(IDL)。gRPC 提供了一种高效、跨语言、跨平台的远程过程调用(RPC)解决方案,被广泛应用于构建分布式系统和微服务架构。以下是选择使用 gRPC 的一些主要原因:

1. 性能高效

  • HTTP/2 协议:gRPC 使用 HTTP/2 协议作为底层的传输协议,相比于 HTTP/1.x 具有更低的延迟、更高的效率和更好的性能。
  • 多路复用:HTTP/2 支持多路复用,允许多个请求同时在一个连接上进行,避免了 HTTP/1.x 中的线头阻塞(Head-of-line blocking)问题。
  • 二进制传输:使用 Protocol Buffers 作为默认的序列化格式,相较于 JSON 和 XML 具有更高的编解码效率,减小了数据传输的体积。

2. 跨语言和跨平台

  • gRPC 的接口定义语言(IDL)使用 Protocol Buffers,支持多种编程语言,如 Java、Go、C++、Python、Ruby 等,使得不同语言的服务能够无缝地进行通信。
  • gRPC 不仅可以在不同的编程语言中使用,还可以在不同的操作系统上运行,包括 Linux、Windows、macOS 等。

3. 接口定义简单

  • 使用 Protocol Buffers 进行接口定义,语法简洁清晰,易于阅读和维护。
  • 支持请求和响应中的复杂数据结构,并提供了方便的工具来生成客户端和服务端的代码。

4. 自动化工具支持

  • gRPC 提供了丰富的工具,如 Protocol Buffers 编译器、gRPC 插件等,使得接口的生成和维护更加方便。
  • 支持使用工具生成客户端和服务端的代码,避免手动编写重复性的代码。

5. 强大的生态系统

  • gRPC 不仅提供了核心的 RPC 功能,还支持服务发现、负载均衡、中间件等功能,使其成为构建微服务架构的理想选择。
  • 有丰富的社区支持,支持的语言和平台不断增加,相关工具和库也在不断完善。

6. 支持流式传输

  • gRPC 支持基于流的传输,允许客户端和服务端通过一个连接同时发送多个消息。
  • 支持单向流、双向流和请求-响应的多种通信模式,适用于各种复杂的应用场景。

7. 安全性

  • gRPC 支持基于 TLS 的安全连接,确保数据在传输过程中的机密性和完整性。
  • 支持多种身份验证机制,包括基于令牌的身份验证、SSL/TLS 证书身份验证等。

8. IDL-First 开发模式

  • gRPC 提倡 Interface Definition Language(IDL)优先的开发模式,通过定义接口的形式来约定服务的行为,确保客户端和服务端之间的一致性。
  • IDL-First 的开发方式使得服务的定义更加清晰,更容易进行版本管理和演化。

选择使用 gRPC 的公司和项目包括 Google、Netflix、Square 等,它在构建高性能、跨语言、分布式系统方面表现出色,成为了现代分布式架构中的一个重要组成部分。


孟斯特

声明:本作品采用署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)进行许可,使用时请注明出处。
Author: mengbin
blog: mengbin
Github: mengbin92
cnblogs: 恋水无意
腾讯云开发者社区:孟斯特


标签:Protocol,gRPC,支持,IDL,HTTP,Why,Buffers
From: https://www.cnblogs.com/lianshuiwuyi/p/17865324.html

相关文章

  • gRPC
    1.gRPC是什么?1.1什么是RPC服务RPC,是RemoteProcedureCall的简称,翻译成中文就是远程过程调用。RPC就是允许程序调用另一个地址空间(通常是另一台机器上)的类方法或函数的一种服务。它是一种架设在计算机网络之上并隐藏底层网络技术,可以像调用本地服务一样调用远端程序,在编码代......
  • Why I see scss file in my chrome inspector?
    WhyIseescssfileinmychromeinspector?BecausetherearemapfilesinyourCSSfolderlike*.css.mapand*.scss.map.Itbasicallyreversemapstheglobal.csswhichisbeingusedbythebrowsertotheconstituent.scssfiles.Theyaretherebecause......
  • GRPC
         ......
  • 【grpc】配置
    @目录写在前面grpc环境搭建nullproto证书1.生成rsakey2.生成cacrt3.生成csr4.openssl.cnf(/usr/lib/ssl/openssl.cnf)【WINDOWS默认为openssl.cfg】5.生成证书私钥test.key6.通过私钥test.key生成证书请求文件test.csr(注意cfg和cnf)7.生成SAN证书然后就可以用在......
  • GRPC - TLS Credentials
    Addingcertificateinformationtoaserverimplementationistwofold:implementlogic toloadcredentialsandcreateaTransportCredentials(http://mng.bz/gBAe)instance; thenusethisfunctionwithintheinterceptortohandlecredentialsverificationout......
  • GRPC - Error Handling
    Unstructured errormessagescancomplicatedecisionmakingwithambiguity.Ifanyservice returnserrormessageswithoutcode,itmightbechallengingtounderstandwhathappenedontheserverside.Therefore,gRPCprovidesastatuspackagetohandleerro......
  • Golang使用grpc实现token拦截
    上一篇简单使用了grpcGolang简单使用grpcserverpackagemainimport( "fmt" "golang.org/x/net/context" "google.golang.org/grpc" "google.golang.org/grpc/codes" "google.golang.org/grpc/grpclog" "google.golang.......
  • Golang实现grpc单向认证
    接着上篇文章写Golang简单使用grpcgolang1.15+版本上,用gRPC通过TLS实现数据传输加密时,会报错证书的问题:rpcerror:code=Unavailabledesc=connectionerror:desc="transport:authenticationhandshakefailed:x509:certificateisnotvalidforanynames,but......
  • GRPC
    先决条件GoProtocolbuffercompiler,protoc,version3https://github.com/protocolbuffers/protobuf/releases/tag/v25.0Gopluginsforprotocolcompiler`goinstallgoogle.golang.org/protobuf/cmd/protoc-gen-go@v1.28``goinstallgoogle.golang.org/grpc/cmd/protoc-ge......
  • API - 几种API接口模式 - RESTful、WebSocket、GraphQL、gRPC、Webhook
    总结TODO.....当思考使用哪种API接口时,你将会面临一个重要的决策。RESTful、GraphQL、gRPC、WebSocket和Webhook是当前流行的几种API接口模式。在本文中,我们将介绍这些接口的特点、用途和比较,帮助你选择最适合你应用程序需求的接口。引言随着现代应用程序的复杂性和用户期望的......