写点什么

gRPC 1.0 发布!

  • 2016-08-29
  • 本文字数:931 字

    阅读完需:约 3 分钟

鉴于 gRPC 已进入稳定版分支,并对应用于生产中准备就绪,Google 发布了 gRPC 1.0

gRPC 源于被称为 Stubby 的 Google 内部项目,早期是用于一些 Google 内部服务间的通信。 18 个月前 Google 开源了 gRPC 框架,希望借此 gRPC 能被更广泛地采纳,并在调用 Google 所提供的服务时、通过互联网与其它服务通信时或在自身产品内部应用 gRPC。

gRPC 是与平台无关的 RPC 系统,它使用 Protocol Buffers (ProtoBuf) IDL 定义终端服务和所传输的消息负载,进而可为多种语言生成存根进程(stub)。当前在 Linux、Mac 和 Windows 平台上,gRPC 支持多达十种语言,分别是: C C++ C# Go Java (包括 Java/Android )、 Node.js Objective-C PHP Python Ruby 。gRPC 原生地使用 C、Go 和 Java 语言编程实现,通过包装 C 函数库提供给其它语言使用。为了显示各种 gRPC 实现的通信延迟情况对比,Google 给出了在同一数据中心中不同虚拟机实例间的通信性能精要报告。对于单一的同步安全消息,报告显示作为基准的 Netperf 的延迟大约为 100 微秒,而 C++、Java 和 C#语言实现的延迟大约在 200 到 300 微秒,Ruby、Python 和 Node.js 语言实现的延迟分别在 700 微秒、900 微秒和 1,100 微秒左右。

gRPC 将需传输的消息使用 Protocol Buffers 3.0 序列化为二进制格式。相对于文本格式而言,ProtoBuf 方式可提供更优的性能。据 Google 工程师 Kelsey Hightower 介绍,ProtoBuf 编码的消息比 JSON 格式消息的大小降低了一半,而序列化和反序列化所用的时间仅为后者的三分之一。

与单一 RPC 中一个请求紧跟着一个响应的方式不同,gPRC 使用 HTTP/2 提供客户和服务器间的单向或双向流。gRPC 支持同步通信和异步通信,及 SSL/TLS 和 OAuth2(使用 Google API)方式的认证。

gRPC 支持以 CocoaPods、gem、Gradle、Maven、npm、NuGet、pecl、pip 或 Docker 镜像等方式提供二进制文件,这简化了安装过程。

据Google 宣称,Cisco、CoreOS、Juniper、Netflix 和Square 等企业内部正在使用gRPC。

查看英文原文: gRPC 1.0 is Ready for Production


感谢百占辉对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2016-08-29 19:004460
用户头像

发布了 227 篇内容, 共 75.5 次阅读, 收获喜欢 28 次。

关注

评论

发布
暂无评论
发现更多内容

【week04】作业

chengjing

消息队列(一)为什么要使用消息队列?

奈何花开

Java MQ 消息队列

一文搞懂 Redis高性能之IO多路复用

架构精进之路

redis io 多路复用 高性能

LeetCode | 6. Valid Parentheses 有效的括号

Puran

算法 LeetCode

架构师训练营 - 第 4 课总结 -20200627- 互联网架构设计

👑👑merlan

架构设计 互联网架构

Week4 学习总结

wyzwlj

极客大学架构师训练营

第四周作业

andy

Go:gsignal,信号大师

陈思敏捷

signal gsignal os.Signal Go 语言

阿里巴巴的发展史(组织变革+技术变革)

王锟

阿里巴巴

架构第四周 - 学习总结

J.Smile

极客大学架构师训练营

互联网架构作业

qihuajun

架构师训练营 - 第四课作业 -20200701- 架构演化

👑👑merlan

极客大学架构师训练营

ARTS|Week 5 有效的括号、API和地图

Puran

LeetCode ARTS 打卡计划

大型互联网公司技术方案与手段浅析

俊俊哥

分布式 高可用 大型软件 高并发 解决方案

架构师面试题(3)

满山李子

架构师训练营 -- 第四周作业

stardust20

第4周总结

andy

通过Python来获取北京市乡镇、街道行政区划数据

Puran

Python GIS geopandas QGIS 天地图

使用数据卷管理数据 | Docker 系列

AlwaysBeta

Docker 容器 数据

每周学习总结 - 架构师培训 4 期

Damon

架构师训练营 - 第四周 - 学习总结

stardust20

极客时间 - 架构师培训 - 4 期作业

Damon

【源码系列】Spring Cloud Eureka

Alex🐒

源码 Spring Cloud Eureka

架构师训练营 -week4 命题作业

J.Smile

极客大学架构师训练营

分布式系统设计 - 第四周作业

孙志平

架构师培训营第四周总结

王锟

消息队列(二)如何保证消息队列的高可用?

奈何花开

Java MQ 消息队列

ARTS打卡 第5周

引花眠

ARTS 打卡计划

互联网架构学习总结

qihuajun

架构师课程第四周 作业

杉松壁

信息的表示与存储-浮点数的运算

引花眠

计算机基础

gRPC 1.0发布!_开源_Abel Avram_InfoQ精选文章