本文介绍了在Python中使用gRPC的方法示例, 具体如下:

使用 Protocol Buffers的跨平台RPC系统。

安装

使用 pip

pip installgrpcio

pipinstall grpcio-tools googleapis-common-protos

gRPC由两个部分构成,grpcio 和 gRPC 工具, 后者是编译 protocol buffer 以及提供生成代码的插件。

使用

编写protocol buffer

使用 gRPC 首先需要做的是设计 protocol buffer。新建一个msg.proto 文件。

syntax = "proto3";

service MsgService {

rpc GetMsg (MsgRequest) returns (MsgResponse){}

}

message MsgRequest {

string name= 1;

}

message MsgResponse {

string msg= 1;

}

以上面的这个消息服务为例,首先是规定语法,这里使用的是 proto3 的语法。接着使用 service 关键字定义服务,gRPC 提供4种 RPC 类型的服务,这里定义的是第一种单一请求单一回应,类似普通的函数调用,其他的使用到了 stream 关键字,将其放在括号里,代表这个数据是流数据。这个以后再来研究,本次先设计一个简单的RPC。

之后定义两个 message ,一个是请求的结构,一个是回应的结果。 这里表示这个数据结构是字符串,protocol buffer 还可以定义为 int32,int64,double,float 等等。这里赋予的初值可以随便填写,实际使用中,会被赋予新的值。

生成接口代码

因为之前安装好了一些辅助插件,使用这里直接可以生成。

python -m grpc_tools.protoc -I . --python_out=. --grpc_python_out=. msg.proto

这里会生成两个文件,msg_pb2.py 和 msg_pb2_grpc.py。这两个文件是为后续的服务端和客户端所用。前者是定义了一些变量,例如 _MSGREQUEST中就包含了请求函数的名字,可接受的变量,实际上还是 msg.proto 里定义的东西。

创建服务端

首先需要导入 RPC 必备的包,以及刚才生成的两个文件。

importgrpcimportmsg_pb2import msg_pb2_grpc

因为 RPC 应该长时间运行,考虑到性能,还需要用到并发的库。

from concurrent importfuturesimporttime

_ONE_DAY_IN_SECONDS= 60 * 60 * 24

在 Server 中,主要是实现服务,按照 msg.proto 定义的,这里需要写一个服务类 MsgServicer ,这个类需要实现之前定义的 GetMsg 。

classMsgServicer(msg_pb2_grpc.MsgServiceServicer):defGetMsg(self, request, context):print("Received name: %s" %request.name)return msg_pb2.MsgResponse(msg='Hello, %s!' % request.name)

GetMsg 接收到的请求是在 request 中, msg.proto 中定义的 name 就是 request.name ,接着在 GetMsg 中设计 msg.proto中定义的MsgResponse 。

之后实现启动服务的部分即可。

defserve():

server= grpc.server(futures.ThreadPoolExecutor(max_workers=10))

msg_pb2_grpc.add_MsgServiceServicer_to_server(MsgServicer(), server)

server.add_insecure_port('[::]:50051')

server.start()try:whileTrue:

time.sleep(_ONE_DAY_IN_SECONDS)exceptKeyboardInterrupt:

server.stop(0)

通过并发库,将服务端放到多进程里运行。

完整 msg_server.py 代码如下

importgrpcimportmsg_pb2importmsg_pb2_grpcfrom concurrent importfuturesimporttime

_ONE_DAY_IN_SECONDS= 60 * 60 * 24

classMsgServicer(msg_pb2_grpc.MsgServiceServicer):defGetMsg(self, request, context):print("Received name: %s" %request.name)return msg_pb2.MsgResponse(msg='Hello, %s!' %request.name)defserve():

server= grpc.server(futures.ThreadPoolExecutor(max_workers=10))

msg_pb2_grpc.add_MsgServiceServicer_to_server(MsgServicer(), server)

server.add_insecure_port('[::]:50051')

server.start()try:whileTrue:

time.sleep(_ONE_DAY_IN_SECONDS)exceptKeyboardInterrupt:

server.stop(0)if __name__ == '__main__':

serve()

创建客户端

客户端相对简单一些,这里我写了一个简单的客户端。

importgrpcimportmsg_pb2importmsg_pb2_grpcdefrun():#NOTE(gRPC Python Team): .close() is possible on a channel and should be

#used in circumstances in which the with statement does not fit the needs

#of the code.

with grpc.insecure_channel('localhost:50051') as channel:

stub=msg_pb2_grpc.MsgServiceStub(channel)

response= stub.GetMsg(msg_pb2.MsgRequest(name='world'))print("Client received:" +response.msg)if __name__ == '__main__':

run()

使用 grpc.insecure_channel('localhost:50051')进行连接 服务端, 接着在这个 channel 上创建 stub , 在 msg_pb2_grpc里可以找到 MsgServiceStub 这个类相关信息。这个 stub 可以调用远程的 GetMsg 函数。 MsgRequest 中的 name 即 msg.proto 中定义的数据。在回应里可以得到 msg.proto 中定义的 msg 。

运行

首先运行

python msg_server.py

启动服务端,接着运行

python msg_client.py

就会看到客户端接收到了服务端传来的消息。

以上就是一个简单的 RPC 的使用。

python grpc_python中grpc的使用示例相关推荐

  1. python grpc 并发_python中grpc的使用示例

    本文介绍了在Python中使用gRPC的方法示例, 具体如下: 使用 Protocol Buffers的跨平台RPC系统. 安装 使用 pip pip installgrpcio pipinstall ...

  2. Python Module — grpcio gRPC 远程调用示例程序

    目录 文章目录 目录 Python gRPC demo 1.使用 Protocol Buffers 来定义 gRPC API 2.实现 Recommendations 微服务 安装依赖 基于 .pro ...

  3. python hashlib_python中hashlib模块用法示例

    我们以前介绍过一篇Python加密的文章:Python 加密的实例详解.今天我们看看python中hashlib模块用法示例,具体如下. hashlib hashlib主要提供字符加密功能,将md5和 ...

  4. Python Web中REST API使用示例——基于云平台+云服务打造自己的在线翻译工具

    做为一个程序员可能在学习技术,了解行业新动态,解决问题时经常需要阅读英文的内容:而像我这样的英文小白就只能借助翻译工具才能理解个大概:不禁经常感慨,英文对学习计算机相关知识太重要了!最近发现IBM的云 ...

  5. python grpc 并发_在Python中使用gRPC的方法示例【h】

    本文介绍了在Python中使用gRPC的方法示例,分享给大家,具体如下: 使用Protocol Buffers的跨平台RPC系统. 安装 使用 pip gRPC由两个部分构成,grpcio 和 gRP ...

  6. python中使用grpc方法示例_在Python中使用gRPC的方法示例

    本文介绍了在Python中使用gRPC的方法示例,分享给大家,具体如下: 使用Protocol Buffers的跨平台RPC系统. 安装 使用 pip pip install grpcio pip i ...

  7. python处理pdf提取指定数据_python从PDF中提取数据的示例

    01 前言 数据是数据科学中任何分析的关键,大多数分析中最常用的数据集类型是存储在逗号分隔值(csv)表中的干净数据.然而,由于可移植文档格式(pdf)文件是最常用的文件格式之一,因此每个数据科学家都 ...

  8. python从字符串中提取数字并转换为相应数据类型_python从PDF中提取数据的示例

    01 前言 数据是数据科学中任何分析的关键,大多数分析中最常用的数据集类型是存储在逗号分隔值(csv)表中的干净数据.然而,由于可移植文档格式(pdf)文件是最常用的文件格式之一,因此每个数据科学家都 ...

  9. Python的collections模块中namedtuple结构使用示例

    namedtuple顾名思义,就是名字+元组的数据结构,下面就来看一下Python的collections模块中namedtuple结构使用示例 namedtuple 就是命名的 tuple,比较像 ...

最新文章

  1. 斯特林数第一类数的应用 hdu3625
  2. python人脸识别opencv_用python和opencv 做人脸识别
  3. jbox2d_JBox2D和JavaFX:事件与力量
  4. Java-数据结构与算法-二分查找法
  5. 理解saltstack 里cmd.run 配合onlyif和unless使用
  6. 怎么用python将日期转化为数字_python实现将中文日期转换为数字日期
  7. 【数据结构笔记04】线性结构:线性表及其实现
  8. UIImageView的animationImages动画
  9. 编译Caffe错误:libpython3.5m.a(abstract.o): relocation R_X86_64_32S against
  10. visual foxpro c语言教程,VFP简单初级入门教程超好.pdf
  11. sap销售发货的流程_基于SAP系统批量创建销售订单及交货单过账的方法与流程
  12. 计算机产品可以进项抵扣,企业购入的软件产品可以全额抵扣进项税吗?
  13. 从字符串中提取IP子串(C语言)
  14. Kotlin 非对称加密RSA
  15. 河北安格计算机专修学院简介,石家庄那23家院校被取消办学资格?
  16. 出现跨域问题的原因及其解决方法
  17. 时间转化为字符串格式的方法
  18. ev3与java_创建一个可启动EV3的SD卡(以便使用Java/lejos)
  19. 胡乱折腾之后,你的脸蛋憔悴了几分?
  20. 某速的体育视频采集分析

热门文章

  1. python怎么检查错误-错误处理
  2. python映射类型-Python中字典映射类型的学习教程
  3. python3.5安装教程-Python 3.5安装教程
  4. pythonweb开发-一步步教你开始使用Python开发Web应用
  5. python自动测试p-python 自动化测试 pytest 的使用
  6. python表白程序-python如何写出表白程序
  7. python爬虫兼职-python爬虫爬取拉勾招聘网
  8. Jetson nano安装JupyterLab
  9. gcc编译报错:undefined reference to `std::cout‘
  10. 使用python moviepy提取视频中的音频,同时对音频数据进行数据可视化分析