gPRC基本介绍

article/2025/10/16 8:05:35

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)_下


http://chatgpt.dhexx.cn/article/ytrBQAFW.shtml

相关文章

自动驾驶时间同步分析概述--PPS/GPRMC/PTP/全域架构时间同步方案

时间同步的重要性在生活中已经充分体现。试想你因一个姑娘在酒吧和别人大打出手,并约定下周六早上九点在后海小树林里进行群体活动。为此你微信召集了在南非、印度、泰国干建筑的好兄弟。可在你如期赴约的时候,发现队友只有河畔的孤影。当你在病床上睁开…

U-BLOX GPS 模块及GPRMC指令解析

受朋友所托,调试一款GPS模块,该模块是UBLOX的NEO-6M GPS模组。想到用这款GPS的人较多,自己日后也有可能在用到这个模块,就写下这份笔记。 一、介绍 基本信息如下: 1、 模块采用U-BLOX NEO-6M模组,体积小巧&…

ROS节点解析GPS数据:GPRMC/GPFDP/HEADINGA

数据解析,肯定是要知道数据格式的: 数据格式参考:(前人已经总结的比较齐全了) https://blog.csdn.net/u010384390/article/details/78432016?ops_request_misc%257B%2522request%255Fid%2522%253A%2522163031225416…

python各种模块,迭代器,生成器

从逻辑上组织python代码(变量,函数,类,逻辑:实现一个功能) 本质就是.py结尾的python文件(文件名:test.py,对应的模块名就是test) 包:用来从逻辑上组织模块的,本质就是一个目录&#…

VFS - 虚拟文件系统的加载和导出

VFS - 代码生成器预览功能实现VFS - 虚拟文件系统基本操作方法的封装VFS - 虚拟文件系统的加载和导出 这是 VFS 的最后一篇,前面两篇中的基本方法已经实现了一个简单的虚拟文件系统,可以创建目录和文件,可以读写文件的内容。在这最后一篇中&a…

如何优雅的使用javascript递归画一棵结构树

递归和尾递归 简单的说,递归就是函数自己调用自己,它作为一种算法在程序设计语言中广泛应用。其核心思想是把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解。一般来说,递归需要有边界条件、递归前进阶段和递归返回阶段…

python数据结构和算法 时间复杂度分析 乱序单词检测 线性数据结构 栈stack 字符匹配 表达式求值 queue队列 链表 递归 动态规划 排序和搜索 树 图

python数据结构和算法 参考 本文github 计算机科学是解决问题的研究。计算机科学使用抽象作为表示过程和数据的工具。抽象的数据类型允许程序员通过隐藏数据的细节来管理问题领域的复杂性。Python是一种强大但易于使用的面向对象语言。列表、元组和字符串都是用Python有序集合…

黑马毕向东Java课程笔记(day20-1——20-17)IO流:File类及相关方法、递归、递归的相关练习、Properties、PrintWriter类与PrintStream类、合并流与切割流

1、File类概述   File是文件和目录路径名的抽象表示形式。 用来将文件或者文件夹封装成对象,方便对文件与文件夹的属性信息进行操作。   前面说到的“流”,它只能操作数据,想要操作由数据封装成的文件的信息,必须使用File对象…

算法: 如何优雅的使用javascript递归画一棵结构树

递归和尾递归 简单的说,递归就是函数自己调用自己,它做为一种算法在程序设计语言中广泛应用。其核心思想是把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解。一般来说,递归需要有边界条件、递归前进阶段和递归返回阶段…

day04函数名 闭包 迭代器 生成器(各种推导式和生成器表达式) 内置函数 装饰器 递归...

一.今日内容概 1. 函数本质就是一个内存地址. 用起来和变量一模一样 2. 闭包 内层函数对外层变量的使用 1. 保护变量 2. 让一个变量常驻内存 3. 迭代器 可迭代对象: __iter__ 迭代器: __iter__ __next__ from collecti…

linux 迭代列出文件,讲解在Linux命令行下使用ls命令列出文件的技巧

Linux ls 命令可以说是在 Linux 中常见到的命令之一,因为使用它可以掌握系统中文件所在目录中的内容,从而能够查看与修改文件,如果你正在使用 Linux ls 命令,不妨看一下以下技巧,它能帮助你更快速的完成任务。 ls 命令…

学习递归的另一种方法

每个学期,我都会通过一项调查,以获取有关我的教学的一些反馈。 上学期终于有人给我写一篇新文章的想法。 特别是,他们想了解有关递归的更多信息,所以我认为我会综合一些技巧。 递归概述 对于那些可能是第一次学习递归的人&#x…

用非递归方法实现递归算法时_学习递归的另一种方法

用非递归方法实现递归算法时 每个学期,我都会通过一项调查,以获取有关我的教学的一些反馈。 上学期终于有人给我写一篇新文章的想法。 特别是,他们想了解有关递归的更多信息,所以我认为我会综合一些技巧。 递归概述 对于那些可能…

bat 文件夹移动

echo off echo hello world ::得到当天 set pathLog%date:~0,4%%date:~5,2%%date:~8,2% :: eg:能得到 秒:set pathLog%date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2% :: set pathLog%pathLog: 0% ::创建文件夹 md "d:\log\log%pathLog% ec…

【Python零基础入门篇 · 19】:os模块、可迭代对象和迭代器对象

目录 一、os模块 1、os模块中的命令: 2、常用命令的代码演示 os.getcwd() os.chdir(path) os.listdir(path) os.mkdir(path) os.makedirs(path) os.rename(旧名,新名) 3、举例:查找文件夹下所有满足要求的文件 二、可迭代对象和迭代器对象 1、…

day18:File(构造方法、创建、删除文件或者文件夹、 判断性、重命名与剪切、得到性、过滤性)、递归(遍历文件夹文件)

一 回顾 1.HashMap集合 特点: A.数据结构也是Hash表结构 B.多线程中是不安全 C.默认的数组的初始化容量是16 2.HashMap与HashSet的比较 相同点:都是hash表结构来存储 不同点: A.HashSet的底层就是使用HashMap来实现 B.HashSet的数据结构针对与是元素 HashMap的…

Python 文件和文件夹 01

Python文件和文件夹 01 ① 修改当前目录,首次利用 pandas 读取 excel 表 os.chdir import os import pandas as pd os.chdir(C:/aa/bb/cc) os.chdir(rC:\aa\bb\cc)数据 pd.read_excel("temp.xlsx") 等同于当前路径下的 temp.xlsx 文件。print(数据)② 字…

删除win10无限嵌套文件夹

解决由于失误操作导致WIN10系统产生无限循环的文件夹问题 昨天本想自己写一个拷贝文件的小程序,结果出现了点小问题,整出了一个无限循环的文件夹,直接删除出出现错误代码提示,显示无法删除,然后我就去网上找解决方案&…

计算机专硕一般研二在干嘛,专硕一般研二在干嘛,专硕两年怎么安排

一般学习两年。 硕士学位的学制取决于您申请的学校和专业。 不同的学校可能不同,同一所学校的硕士学位也可能不同。 许多学校还设有两年半的学制,甚至三年制的学制。本文一起来看一下吧~ 一.什么人适合读专硕 1、英语相对一般的人 学硕主要考英语一试卷&…

研二导师画大饼,不给时间实习,咋办

一个小学弟最近咨询我 我是本硕都在一所双非一本就读,软件工程,目前研二,23 届。我想在暑期进行一下今年的实习,想着可能对后面秋招和来年春招有帮助,但是实验室管的严导师不放时间(其实我当时是为了毕业条件和平时研…