师父给了我一个 .proto 文件,我应该怎么使用?

简介: 师父给了我一个 .proto 文件,我应该怎么使用?

摄影:产品经理脆脆的烤鱼皮

回想我年轻的时候,在做一个项目时,需要计算斐波那契数列第 n 项的值。但是我只会使用递归来实现。众所周知,递归算法计算斐波那契数列的效率极差,速度极慢。

于是我求助于当时我的师父,问他有没有办法帮我解决这个问题。

我师父说:“有啊,我写过,但是代码是用C++ 写的,你估计看不懂。不过没关系,你用 Python 直接调用就可以了。”

我很惊讶:“用 Python 直接调用C++代码吗?看起来似乎很麻烦啊。”

师父说:“一点也不麻烦。我给你一个.proto 文件和一个地址,你拿去自动生成代码就能调用了。”

于是,我拿到了一个mentors_secret.proto文件,里面的内容非常简单:

syntax = "proto3";
message NumToCalc {
    int32 num = 1;
}
message Result {
    int32 result = 1;
    string msg = 2;
    bool success = 3;
}
service MentorsSecret {
    rpc CalcFib(NumToCalc) returns (Result) {}
}

还有一个地址:122.51.39.219:8766

原来是使用 gRPC 啊。这样我就知道怎么做了。

安装环境

首先,我们先安装Python 版本的gRPC:

pip install grpcio grpcio-tools

生成代码

接下来,基于这个mentors_secret.proto文件,自动生成代码。cd进入mentors_secret.proto文件所在的文件,执行下面的命令:

python3 -m grpc_tools.protoc -I . --python_out=. --grpc_python_out=. ./mentors_secret.proto

此时,可以看到当前文件夹中生成了两个文件:mentors_secret_pb2.pymentors_secret_pb2_grpc.py

如下图所示:

这两个文件的内容,不需要看

调用远程服务

接下来,创建一个新文件,叫做client.py,用来调用远程的函数:

import grpc
from mentors_secret_pb2 import NumToCalc
from mentors_secret_pb2_grpc import MentorsSecretStub
channel = grpc.insecure_channel('122.51.39.219:8766')
stub = MentorsSecretStub(channel)
result = stub.CalcFib(NumToCalc(num=36))
print('斐波那契数列第36像是:', result.result)

代码加上空行总共只有10行。1-3行导入模块,6,7行创建远程链接。第9行调用远程的函数。第10行打印结果。

我们来看看运行效果:


运行结果秒出。

总结

当我们拿到一个.proto文件,需要去调用gRPC 服务时,我们一般有如下步骤:

  1. 自动生成mentors_secret_pb2.pymentors_secret_pb2_grpc.py文件。
  2. 查看.proto文件里面,service后面的名字MentorsSecret,如下图所示:

  1. 编写固定的代码:
import grpc
from mentors_secret_pb2_grpc import MentorsSecretStub # service 名字后面加上 Stub
channel = grpc.insecure_channel('远程服务地址和 端口')
stub = MentorsSecretStub(channel)
  1. 调用远程函数。通过.proto文件,可以知道远程函数CalcFib接收一个参数NumToCalc,所以把它导入进来:from mentors_secret_pb2 import NumToCalc,它里面的参数为num,所以调用远程服务时赋值:
para = NumToCalc(num=36)
calc_result = stub.CalcFib(para)
  1. .proto知道返回的结果是Result里面的result属性。于是打印calc_result.result获得结果。

本文中的 gRPC 地址122.51.39.219:8766,我会给大家保留到2020-11-05。有兴趣的同学,可以自己测试一下。

目录
相关文章
|
5月前
|
XML 设计模式 JSON
Go - 关于 proto 文件的一点小思考?
Go - 关于 proto 文件的一点小思考?
60 0
|
7月前
介绍文档:proto 文件的关键字介绍
介绍文档:proto 文件的关键字介绍
234 6
|
7月前
|
C++
gRPC接口怎样从proto文件到具体使用
gRPC接口怎样从proto文件到具体使用
57 6
|
8月前
|
Linux Shell 开发工具
C++ 的 ini 配置文件读写/注释库 inicpp 用法 [ header-file-only ]
这是一个C++库,名为inicpp,用于读写带有注释的INI配置文件,仅包含一个hpp头文件,无需编译,支持C++11及以上版本。该库提供简单的接口,使得操作INI文件变得容易。用户可通过`git clone`从GitHub或Gitee获取库,并通过包含`inicpp.hpp`来使用`inicpp::iniReader`类。示例代码展示了读取、写入配置项以及添加注释的功能,还提供了转换为字符串、双精度和整型的函数。项目遵循MIT许可证,示例代码可在Linux环境下编译运行。
574 0
|
8月前
|
C++
vs2017下gRPC的编译以及简单使用
vs2017下gRPC的编译以及简单使用
168 0
|
测试技术 Go
gRPC源码分析(四):剖析Proto序列化
首先,针对读源码是先看源代码还是测试代码,因人而异。个人建议在对源码毫无头绪时,先从测试入手,了解大致功能;如果有一定基础,那么也可以直接入手源代码。我认为优秀的Go源码可读性是非常高的,所以一般情况下,我都直接从源文件入手,遇到问题才会去对应的测试里阅读。
137 1
|
JSON Go PHP
Protobuf 的 proto3 与 proto2 的区别
Protobuf 的 proto3 与 proto2 的区别
318 0
|
JSON Go 数据格式
Golang 语言 Struct 中字段的 Tag 怎么使用?
Golang 语言 Struct 中字段的 Tag 怎么使用?
65 0
|
Java 程序员 API
代码看起来一点也不优雅,试试Stream
代码看起来一点也不优雅,试试Stream
76 0
|
Linux
LINUX编译xcb/xcb-proto
LINUX编译xcb/xcb-proto
212 0

热门文章

最新文章

下一篇
开通oss服务