在Python中使用gRPC的方法示例


Posted in Python onAugust 08, 2018

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

在Python中使用gRPC的方法示例

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

安装

使用 pip

pip install grpcio
pip install 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 . --pythoout=. --grpc_python_out=. msg.proto

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

创建服务端

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

import grpc
import msg_pb2
import msg_pb2_grpc

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

from concurrent import futures
import time

_ONE_DAY_IN_SECONDS = 60 * 60 * 24

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

class MsgServicer(msg_pb2_grpc.MsgServiceServicer):

  def GetMsg(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

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

def serve():
  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:
    while True:
      time.sleep(_ONE_DAY_IN_SECONDS)
  except KeyboardInterrupt:
    server.stop(0)

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

完整 msg_server.py 代码如下

import grpc
import msg_pb2
import msg_pb2_grpc

from concurrent import futures
import time

_ONE_DAY_IN_SECONDS = 60 * 60 * 24


class MsgServicer(msg_pb2_grpc.MsgServiceServicer):

  def GetMsg(self, request, context):
    print("Received name: %s" % request.name)
    return msg_pb2.MsgResponse(msg='Hello, %s!' % request.name)


def serve():
  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:
    while True:
      time.sleep(_ONE_DAY_IN_SECONDS)
  except KeyboardInterrupt:
    server.stop(0)

if __name__ == '__main__':
  serve()

创建客户端

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

import grpc

import msg_pb2
import msg_pb2_grpc

def run():
  # 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 中的 namemsg.proto 中定义的数据。在回应里可以得到 msg.proto 中定义的 msg

运行

首先运行 python msg_server.py 启动服务端,接着运行 python msg_client.py 机会看到客户端接收到了服务端传来的消息。以上就是一个简单的 RPC 的使用。

总结

这里只是简单的用了一下 gRPC,关于另外三种模式,还在摸索。比起gRPC,我感觉简单 RestFul 更讨我喜欢。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现3行代码解简单的一元一次方程
Aug 18 Python
Python中的作用域规则详解
Jan 30 Python
python_opencv用线段画封闭矩形的实例
Dec 05 Python
在Pycharm中对代码进行注释和缩进的方法详解
Jan 20 Python
PowerBI和Python关于数据分析的对比
Jul 11 Python
python百行代码自制电脑端网速悬浮窗的实现
May 12 Python
Python Switch Case三种实现方法代码实例
Jun 18 Python
Django:使用filter的pk进行多值查询操作
Jul 15 Python
Selenium 配置启动项参数的方法
Dec 04 Python
Python-OpenCV实现图像缺陷检测的实例
Jun 11 Python
详解如何用Python实现感知器算法
Jun 18 Python
再谈python_tkinter弹出对话框创建
Mar 20 Python
Python实现购物评论文本情感分析操作【基于中文文本挖掘库snownlp】
Aug 07 #Python
python实现彩票系统
Jun 28 #Python
django框架自定义用户表操作示例
Aug 07 #Python
Python实现基于POS算法的区块链
Aug 07 #Python
tensorflow学习教程之文本分类详析
Aug 07 #Python
Django添加feeds功能的示例
Aug 07 #Python
Python爬虫实现抓取京东店铺信息及下载图片功能示例
Aug 07 #Python
You might like
PHP导入Excel到MySQL的方法
2011/04/23 PHP
php修改时间格式的代码
2011/05/29 PHP
php检查日期函数checkdate用法实例
2015/03/19 PHP
php实现中文转数字
2016/02/18 PHP
Yii使用migrate命令执行sql语句的方法
2016/03/15 PHP
PHP  实现等比压缩图片尺寸和大小实例代码
2016/10/08 PHP
一组JS创建和操作表格的函数集合
2009/05/07 Javascript
动态表格Table类的实现
2009/08/26 Javascript
jquery向.ashx文件post中文乱码问题的解决方法
2011/03/28 Javascript
让浏览器DOM元素最后加载的js方法
2014/07/29 Javascript
简介EasyUI datagrid editor combogrid搜索框的实现
2016/04/01 Javascript
Angular.js中用ng-repeat-start实现自定义显示
2016/10/18 Javascript
jQuery实现对网页节点的增删改查功能示例
2017/09/18 jQuery
js实现单张图片平移切换效果
2017/10/11 Javascript
AngularJS 事件发布机制
2018/08/28 Javascript
Jquery获取radio选中值实例总结
2019/01/17 jQuery
如何正确理解vue中的key详解
2019/11/02 Javascript
浅谈Vue.js之初始化el以及数据的绑定说明
2019/11/14 Javascript
Chrome插件开发系列一:弹窗终结者开发实战
2020/10/02 Javascript
[00:36]DOTA2上海特级锦标赛 Archon战队宣传片
2016/03/04 DOTA
python实现人人网登录示例分享
2014/01/19 Python
Python装饰器decorator用法实例
2014/11/10 Python
Python使用requests及BeautifulSoup构建爬虫实例代码
2018/01/24 Python
python简单实现操作Mysql数据库
2018/01/29 Python
python实现百度语音识别api
2018/04/10 Python
详解python中TCP协议中的粘包问题
2019/03/22 Python
Python发送手机动态验证码代码实例
2020/02/28 Python
Anaconda+vscode+pytorch环境搭建过程详解
2020/05/25 Python
3分钟看懂Python后端必须知道的Django的信号机制
2020/07/26 Python
Python使用requests模块爬取百度翻译
2020/08/25 Python
纯CSS3制作页面切换效果的实例代码
2019/05/30 HTML / CSS
英国潮流网站:END.(全球免邮)
2017/01/16 全球购物
保险内勤岗位职责
2014/04/05 职场文书
初一年级组工作总结
2015/08/12 职场文书
你会写请假条吗?
2019/06/26 职场文书
导游词之海南-南湾猴岛
2019/10/12 职场文书