文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-12-03 18:11

关注

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

[[350118]]

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

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

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

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

  1. syntax = "proto3"
  2.  
  3.  
  4. message NumToCalc { 
  5.     int32 num = 1
  6.  
  7.  
  8. message Result { 
  9.     int32 result = 1
  10.     string msg = 2
  11.     bool success = 3
  12.  
  13.  
  14. service MentorsSecret { 
  15.     rpc CalcFib(NumToCalc) returns (Result) {} 

还有一个地址:122.51.39.219:8766。

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

安装环境

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

  1. pip install grpcio grpcio-tools 

生成代码

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

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

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

如下图所示:

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

调用远程服务

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

  1. import grpc 
  2. from mentors_secret_pb2 import NumToCalc 
  3. from mentors_secret_pb2_grpc import MentorsSecretStub 
  4.  
  5.  
  6. channel = grpc.insecure_channel('122.51.39.219:8766') 
  7. stub = MentorsSecretStub(channel) 
  8.  
  9. result = stub.CalcFib(NumToCalc(num=36)) 
  10. print('斐波那契数列第36像是:', result.result) 

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

我们来看看运行效果:

运行结果秒出。

总结

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

(1) 自动生成mentors_secret_pb2.py和mentors_secret_pb2_grpc.py文件。

(2) 查看.proto文件里面,service后面的名字MentorsSecret,如下图所示:

(3) 编写固定的代码:

  1. import grpc 
  2. from mentors_secret_pb2_grpc import MentorsSecretStub # service 名字后面加上 Stub 
  3.  
  4.  
  5. channel = grpc.insecure_channel('远程服务地址和 端口') 
  6. stub = MentorsSecretStub(channel) 

(4) 调用远程函数。通过.proto文件,可以知道远程函数CalcFib接收一个参数NumToCalc,所以把它导入进来:from mentors_secret_pb2 import NumToCalc,它里面的参数为num,所以调用远程服务时赋值:

  1. para = NumToCalc(num=36
  2. calc_result = stub.CalcFib(para) 

(5) 从.proto知道返回的结果是Result里面的result属性。于是打印calc_result.result获得结果。

 

来源:未闻Code内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯