grpc第一篇:What is gRPC

本文将介绍gRPC和protocol buffers。gRPC可以利用protocol buffers作为其接口定义语言(Interface Definition Language,IDL)和信息交换格式。

预览

在gRPC中,一个客户端应用可以直接调用不同机器上的服务端应用的方法,就好像调用本地方法一样,这使得创建分布式应用和服务变得很容易。和许多RPC系统一样,gRPC基本思想是定义服务,指定可以被远程调用的方法及其入参和返回类型。在服务端一侧,服务端实现这个接口并运行一个gRPC服务来处理客户端调用。在客户端一侧,客户端有一个stub(在有些语言中叫做client),提供和服务端相同的方法。

gRPC客户端和服务端可以用不同的语言,如客户端用java,服务端用python。支持的语言有java、python、c、c++、c#、go等。

默认情况下,gRPC用protocol buffers。protocol buffers是google开源的一套数据序列化方案,目前已经很成熟。当然,gRPC也可以用json。当用protocol buffers时,首先要在proto文件中定义要序列化的数据的结构。示例:

message Person {
    string name = 1;
    int32 id = 2;
    bool married = 3;
}

注意,数据类型都是小写的。

在proto文件中还要定义service,入参和返回类型都是protocol buffer message。示例:

复制代码
syntax = "proto3";

option go_package = "example.com/project/protos/fizz";

message HelloRequest {
    string name = 1;
}

message HelloReply {
    string message = 1;
}

service Greeter {
    rpc SayHello (HelloRequest) returns (HelloReply);
}
复制代码

注意,方法名首字母大写。

go_package解释见:

https://protobuf.dev/reference/go/go-generated/#package

posted on   koushr  阅读(201)  评论(0编辑  收藏  举报

编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示