gRPC-初识Protocol Buffers

简介

gRPC gRPC是一个高性能、开源和通用的 RPC 框架,面向移动和 HTTP/2 设计。gRPC 基于 HTTP/2 标准设计,带来双向流、流控、头部压缩、单 TCP 连接上的多复用请求等特性。这些特性使得其在移动设备上表现更好,更省电和节省空间占用。

特点

协议

基于 HTTP/2 标准设计,带来双向流、流控、头部压缩、单 TCP 连接上的多复用请求等特性。这些特性使得其在移动设备上表现更好,更省电和节省空间占用。

序列化

gRPC 默认使用 Protocol Buffers 作为 RPC 序列化框架。Protocol Buffers是由Google开发的一种数据序列化协议。序列化内容更小,更快更简洁。而且一次定义,可生成多种语言的代码。

Protocol Buffers

一般使用 proto3 的新风格的 protocol buffers,它拥有轻量简化的语法、一些有用的新功能,并且支持更多新语言。

proto3语法

文件格式

* .proto 为文件后缀名

版本

复制代码
syntax = "proto3";

注释

bash 复制代码
//    单行注释

/*
      多行注释
*/

Java相关

bash 复制代码
// 一个源文件还是多个源文件
option java_multiple_files = true;
// 源文件放置的包名
option java_package = "com.agi.grpc";
// Java外部类名字,[内部类用于开发]
option java_outer_classname = "Demo";

逻辑包

bash 复制代码
// 便于内容管理
package demo;

导入

bash 复制代码
import "Demo.proto";

枚举 enum

枚举必须0开始

bash 复制代码
enum SEASON{
  SPRING = 0;
  SUMMER = 1;
  AUTUMN = 2;
  WINTER = 3;
}

消息 message

bash 复制代码
message Resp{
  //成员变量类型 成员变量名字 序列化顺序(不能重复,范围1-2^29-1)
  string msg = 1;
  int32 code = 2;
}

repeatedly

bash 复制代码
message Resp{
  // 多个数据,相当于Java中的List
  repeated string list= 1;
}

多个消息

bash 复制代码
message Resp{
  //成员变量类型 成员变量名字 序列化顺序(不能重复,唯一即可,范围1-2^29-1)
  string msg = 1;
  int32 code = 2;
}

message Resp{
  // 多个数据,相当于Java中的List
  repeated string list= 1;
}

嵌套消息

bash 复制代码
message Resp{
  message Data{
    int64 id = 1;
    string name = 2;
  }
  //成员变量类型 成员变量名字 序列化顺序(不能重复)
  string msg = 1;
  int32 code = 2;
  // List<Data>
  repeated Data data = 3;
}

oneof

可取值为其中一个

复制代码
message Response{
  oneof test{
    int64 id = 1;
    string name = 2;
  }
}
相关推荐
白晨并不是很能熬夜4 天前
【RPC】第 4 篇:服务发现 — Zookeeper + 缓存容错
java·后端·程序人生·缓存·zookeeper·rpc·服务发现
信徒_4 天前
技术选型 RPC 框架
网络·网络协议·rpc
Andya_net4 天前
Spring | 深度剖析Spring Bean的生命周期:从加载到销毁的完整流程
java·spring·rpc
染夕陌木5 天前
RPC/服务调用框架中“方法无法应用到给定类型”错误的通用排查指南
java·ide·rpc
Albert Edison6 天前
【RabbitMQ】RPC 通信(使用案例)
分布式·rpc·rabbitmq
lifewange6 天前
RPC 是什么
网络·网络协议·rpc
白晨并不是很能熬夜6 天前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio
白晨并不是很能熬夜6 天前
【RPC】第 1 篇:全景篇 — 一次 RPC 调用的完整旅程
java·网络·后端·网络协议·面试·rpc·java-zookeeper
珹洺7 天前
C++远程调用组件库JsonRpc(一)项目背景、核心概念与环境搭建
开发语言·c++·rpc
星辰_mya11 天前
RPC 原理:Dubbo为了偷懒而存在的中间商
后端·网络协议·rpc·架构·dubbo