1.说明

gRPC英文全名为Google Remote Procedure Call,
即Google远程过程调用,
是Google发布的一个高性能、通用的开源RPC框架,

2.gRPC定义

gRPC是一个现代的开源高性能RPC框架,
可以在任何环境中运行。
它可以高效地连接数据中心内和跨数据中心的服务,
支持可插拔的负载平衡、跟踪、运行状况检查和身份验证。
它也适用于分布式计算的最后一英里连接设备,
移动应用程序和浏览器后端服务。

gRPC提供了一种简单的方法来精确地定义服务,
使用Protocol Buffers定义服务,
为iOS、Android和后台支持服务自动生成可靠性很强的客户端功能库。
基于HTTP/2传输层标准协议设计的,
可以设置为同步或者异步通讯。

gRPC提供了支持多种编程语言的、
对网络设备进行配置和管理的方法。
通信双方可以基于该软件框架进行二次开发。

3.为什么使用gRPC

我们的例子是一个简单的路由映射的应用,
它允许客户端获取路由特性的信息,
生成路由的总结,
以及交互路由信息,
如服务器和其他客户端的流量更新。

有了gRPC,
我们可以一次性的在一个.proto文件中定义服务,
并使用任何支持它的语言去实现客户端和服务器,
反过来,它们可以在各种环境中,
从Google的服务器到你自己的平板电脑,
gRPC帮你解决了不同语言及环境间通信的复杂性。
使用Protocol Buffers还能获得其他好处,
包括高效的序列化,
简单的IDL以及容易进行接口更新。

3.1.简单的服务定义

使用Protocol Buffers定义服务,
Protocol Buffers是一种强大的二进制序列化工具集和语言。

3.2.快速启动并扩大规模

使用单行安装运行时和开发环境,并使用框架扩展到每秒数百万个rpc。

3.3.跨语言和平台工作

以各种语言和平台为你的服务自动生成惯用的客户端和服务器存根。

3.4.双向流和集成认证

双向流和完全集成了基于HTTP/2的传输的可插拔身份验证。

4.协议栈

gRPC协议栈分层模型:

分层 说明
消息内容层 业务模块的通信双方需要了解彼此的数据模型,才能正确处理数据
Protocol Buffers编码层 gRPC通过Protocol Buffers编码格式承载数据
gRPC层 远程过程调用,定义了远程过程调用的协议交互格式
HTTP层 gRPC承载在HTTP/2协议上
TCP层 TCP连接提供面向连接的、可靠的数据链路

5.网络架构

gRPC网络采用客户端/服务器模型,
使用HTTP/2协议传输报文:

gRPC网络的工作机制:

  1. 服务器通过监听指定服务端口来等待客户端的连接请求。
  2. 用户通过执行客户端程序登录到服务器。
  3. 客户端调用.proto文件提供的gRPC方法发送请求消息。
  4. 服务器回复应答消息。

服务器和客户端可以是任意语言编写的,
不需要保持一致,
服务端可以是C++编写的,
客户端可以是Java编写的,
通信双方只要支持gRPC,
不关心具体使用的编程语言。

6.支持开发语言

由于gRPC提供使用Protocol Buffers定义服务,
Protobuf3是类似json,xml的数据交换协议,
但是它比它们传输的数据更小,传输的速度更快;
跨语言交互,支持大部分主流编程语言:

C++
C#/.NET
Objective-C
Dart
Go
Java
Android Java
Kotlin/JVM
Node.js
Ruby
Web
PHP
Python

还有更多支持语言在开发中。

7.参考文章

Supported languages and platforms
gRPC创建Java RPC服务
ProtoBuf3语法指南(Protocol Buffers)_上
ProtoBuf3语法指南(Protocol Buffers)_下

gPRC基本介绍的更多相关文章

  1. grpc介绍

    grpc入门(一) 一.什么是grpc grpc是谷歌开源的一款高性能的rpc框架 (https://grpc.io),可以使用protocol buffers作为IDL(Interface Defi ...

  2. Nginx接入gPRC

    gPRC官网:https://grpc.io/ NGINX将在1.13.10版本中包含grpc相关功能 这个版本支持NGINX代理gRPC TCP连接.可以用来: 发布gRPC服务,包括未加密/加密的 ...

  3. 微服务系列(二)GRPC的介绍与安装

    微服务系列(二)GRPC的介绍与安装 1.GPRC简介 GRPC是Google公司基于Protobuf开发的跨语言的开源RPC框架.GRPC基于HTTP/2协议设计,可以基于一个HTTP/2链接提供多 ...

  4. CSS3 background-image背景图片相关介绍

    这里将会介绍如何通过background-image设置背景图片,以及背景图片的平铺.拉伸.偏移.设置大小等操作. 1. 背景图片样式分类 CSS中设置元素背景图片及其背景图片样式的属性主要以下几个: ...

  5. MySQL高级知识- MySQL的架构介绍

    [TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...

  6. Windows Server 2012 NIC Teaming介绍及注意事项

    Windows Server 2012 NIC Teaming介绍及注意事项 转载自:http://www.it165.net/os/html/201303/4799.html Windows Ser ...

  7. Linux下服务器端开发流程及相关工具介绍(C++)

    去年刚毕业来公司后,做为新人,发现很多东西都没有文档,各种工具和地址都是口口相传的,而且很多时候都是不知道有哪些工具可以使用,所以当时就想把自己接触到的这些东西记录下来,为后来者提供参考,相当于一个路 ...

  8. JavaScript var关键字、变量的状态、异常处理、命名规范等介绍

    本篇主要介绍var关键字.变量的undefined和null状态.异常处理.命名规范. 目录 1. var 关键字:介绍var关键字的使用. 2. 变量的状态:介绍变量的未定义.已定义未赋值.已定义已 ...

  9. HTML DOM 介绍

    本篇主要介绍DOM内容.DOM 节点.节点属性以及获取HTML元素的方法. 目录 1. 介绍 DOM:介绍DOM,以及对DOM分类和功能的说明. 2. DOM 节点:介绍DOM节点分类和节点层次. 3 ...

随机推荐

  1. linux之sar命令详解

    sar(System Activity Reporter系统活动情况报告)是目前Linux上最为全面的系统性能分析工具之一,可以从多个方面对系统的活动进行报告,包括:文件的读写情况.系统调用的使用情况 ...

  2. Output of C++ Program | Set 18

    Predict the output of following C++ programs. Question 1 1 #include <iostream> 2 using namespa ...

  3. 一份不错的Java就业指导

    想要成为合格的Java程序员或工程师到底需要具备哪些专业技能,面试者在面试之前到底需要准备哪些东西呢? 本文陈列的这些内容既可以作为个人简历中的内容,也可以作为面试的时候跟面试官聊的东西,你可以把这些 ...

  4. Linux:while read line与for循环的区别

    while read line:是一次性将文件信息读入并赋值给变量line , while中使用重定向机制,文件中的所有信息都被读入并重定向给了整个while 语句中的line 变量. for:是每次 ...

  5. liunx 安装ActiveMQ 及 spring boot 初步整合 activemq

    源码地址:  https://gitee.com/kevin9401/microservice.git 一.安装 ActiveMQ: 1. 下载 ActiveMQ wget  https://arch ...

  6. 【C/C++】算法入门:排序/算法笔记

    (设排序从小到大) 冒泡排序 这个大家都会,从第一个开始往后俩俩交换,然后第二个,最后到最后一个,复杂度n^2 选择排序 思路和冒泡差不多,比如要得到从小到大的排序,就是从第一个开始,i取1~n,每次 ...

  7. Centos7源码部署Redis3.2.9

    目录 一.环境准备 二.安装 三.测试 四.编写启动脚本 一.环境准备 [Redis-Server] 主机名 = host-1 系统 = centos-7.3 地址 = 1.1.1.1 软件 = re ...

  8. 软件开发生命周期(SDLC)

    一.简介 软件开发生命周期又叫做 SDLC(Software Development Life Cycle),它是集合了计划.开发.测试和部署过程的集合.如下图所示 : 二.五个阶段 1.分析阶段: ...

  9. 【.NET 与树莓派】WS28XX 灯带的颜色渐变动画

    在上一篇水文中,老周演示了 WS28XX 的基本使用.在文末老周说了本篇介绍颜色渐变动画的简单实现. 在正式开始前,说一下题外话. 第一件事,最近树莓派的价格猛涨,相信有关注的朋友都知道了.所以,如果 ...

  10. Elasticsearch核心技术(四):索引原理分析

    本文探讨Elasticsearch的数据请求.路由和写入过程的原理,主要涉及ES的分布式存储架构.节点和副本的写入过程.近实时搜索的原因.持久化机制等. 4.1 ES存储架构 我们经常说,看一件事情千 ...