菜单

grpc在django中的使用

2019年4月7日 - 金沙编程资讯

python3 -m
grpc_tools.protoc -I. –python_out=. –grpc_python_out=.
data.proto

实践:

上面我们选拔 g福特ExplorerPC
定义三个接口,该接口完结对传播的多少开始展览大写的格式化处理。

![](https://upload-images.jianshu.io/upload_images/208550-bd34d08e0c12cdeb.png)

Paste\_Image.png
  1. client目录下的 main.py 完结了客户端用于发送数据并打字与印刷接收到 server
    端处理后的多少
  1. server 目录下的 main.py 达成了 server
    端用于吸收接纳客户端发送的数目,并对数据进行大写处理后重临给客户端
  2. example 包用于编写 proto 文件并扭转 data 接口

syntax = "proto3";
package example;
service FormatData {
  rpc DoFormat(Data) returns (Data){}
}
message Data {
  string text = 1;
}

$ python -m grpc_tools.protoc -I. –python_out=.
–grpc_python_out=. ./data.proto #在 example
目录中举行编写翻译,会转变:data_pb2.py 与 data_pb2_grpc.py

#! /usr/bin/env python
# -*- coding: utf-8 -*-
import grpc
import time
from concurrent import futures
from example import data_pb2, data_pb2_grpc

_ONE_DAY_IN_SECONDS = 60 * 60 * 24
_HOST = 'localhost'
_PORT = '8080'

class FormatData(data_pb2_grpc.FormatDataServicer):
    def DoFormat(self, request, context):
        str = request.text
        return data_pb2.Data(text=str.upper())

def serve():
    grpcServer = grpc.server(futures.ThreadPoolExecutor(max_workers=4))
    data_pb2_grpc.add_FormatDataServicer_to_server(FormatData(), grpcServer)
    grpcServer.add_insecure_port(_HOST + ':' + _PORT)
    grpcServer.start()
    try:
        while True:
            time.sleep(_ONE_DAY_IN_SECONDS)
    except KeyboardInterrupt:
        grpcServer.stop(0)

if __name__ == '__main__':
    serve()

#! /usr/bin/env python
# -*- coding: utf-8 -*-
import grpc
from example import data_pb2, data_pb2_grpc

_HOST = 'localhost'
_PORT = '8080'

def run():
    conn = grpc.insecure_channel(_HOST + ':' + _PORT)
    client = data_pb2_grpc.FormatDataStub(channel=conn)
    response = client.DoFormat(data_pb2.Data(text='hello,world!'))
    print("received: " + response.text)

if __name__ == '__main__':
    run()
  1. 先运转 server,之后再实施 client
  1. client 侧控制台假使打字与印刷的结果为:“received: HELLO,WOCRUISERLD!” ,注脚g奥迪Q5PC 接口定义成功

图片 1

qq群.jpg

运维时只要求周转该脚本即可,django服务不必启用

ProtoBuf: 是壹套完整的 IDL(接口描述语言),出自Google,基于 C++
举行的落实,开发人士能够根据 ProtoBuf
的语言专业生成多样编制程序语言(Golang、Python、Java
等)的接口代码,本篇只讲述 Python 的底子操作。据说 ProtoBuf
所生成的二进制文件在蕴藏作用上比 XML 高 3~十 倍,并且处理品质高 一~一个数据级,那也是选取 ProtoBuf 作为系列化方案的一个重中之重成分之1。

pip
install grpcio

安装:

  1. gRPC 的安装:

$ pip install grpcio

  1. 安装 ProtoBuf 相关的 python 依赖库:

$ pip install protobuf

  1. 设置 python grpc 的 protobuf 编写翻译工具:

$ pip install grpcio-tools

此间解释一下,python(不解释) -m(也不表达)
grpc_tools.protoc(上边安装的三方)
-I./protos(标识当前目录下的protos文件夹,xxx.proto需求在那些文件夹中)
–python_out=.(当前目录生成输出文件)
–grpc_python_out=.(当前目录生成grpc文件)
./protos/xxx.proto(xxx.proto的相对路径)

安装:

  1. 安装 protoc
    :Protoc下载地址,可以根据本人的系统下载相应的
    protoc,windows 用户统一下载 win3二 版本。
  2. 布局 protoc 到系统的环境变量中,执行如下命令查看是还是不是安装成功:

$ protoc –version
要是不奇怪打印 libprotoc 的版本音讯就标志 protoc 安装成功

  1. 安装 ProtoBuf 相关的 python 依赖库

$ pip install protobuf

data_pb2.py是劳务接口映射

gRPC 简介:

gTucsonPC 是一款高品质、开源的 牧马人PC 框架,产自 谷歌,基于 ProtoBuf
种类化协议进行付出,帮衬四种语言(Golang、Python、Java等),本篇只介绍
Python 的 g福睿斯PC 使用。因为 g凯雷德PC 对 HTTP/2 协议的扶助使其在 Android、IOS
等客户端后端服务的支出世界具有优秀的前景。gGL450PC
提供了1种简单的方式来定义服务,同时客户端可以丰盛利用 HTTP/2 stream
的表征,从而有助于节省带宽、降低 TCP 的总是次数、节省CPU的应用等。

千帆竞发尝试是在python脚本中与java对接接口,日常官方文书档案的1顿学习,成功调通了接口

使用

  1. 创建 demo python 工程
![](https://upload-images.jianshu.io/upload_images/208550-efc7e919daa289de.png)

Paste\_Image.png
  1. 在 example 包中编辑 person.proto

    syntax = "proto3";
    package example;
    
    message person {   
        int32 id = 1;
        string name = 2;
    }
    
    message all_person {    
        repeated person Per = 1;
    }
    
  2. 进入 demo 工程的 example 目录,使用 protoc 编译 person.proto

$ protoc –python_out=. person.proto
就会变卦 person_pb2.py 文件

  1. 在 python 工程中运用 protobuf 举办系列化与反体系化
    main.py:

    #! /usr/bin/env python
    # -*- coding: utf-8 -*-
    from example import person_pb2
    
    # 为 all_person 填充数据
    pers = person_pb2.all_person()
    p1 = pers.Per.add()
    p1.id = 1
    p1.name = 'xieyanke'
    p2 = pers.Per.add()
    p2.id = 2
    p2.name = 'pythoner'
    
    # 对数据进行序列化
    data = pers.SerializeToString()
    
    # 对已经序列化的数据进行反序列化
    target = person_pb2.all_person()
    target.ParseFromString(data)
    print(target.Per[1].name)  #  打印第一个 person name 的值进行反序列化验证
    

图片 2

qq群.jpg

 

四.部分左近原型的生成python类的聚合:

python -m grpc_tools.protoc -I./protos –python_out=.
–grpc_python_out=. ./protos/xxx.proto

编写翻译protobuf文件:使用以下命令生成Python代码:


 

不久前在做微服务那壹块,后端与java合营,自个儿是python的,所以思考采用grpc,一点思量是grpc是http二.0,另壹些设想是十三分供给的:)

1.grpc安装

自己既想用django的model又想用grpc该如何是好吧,django是八个劳动,grpc是多个劳动,直接暴力把grpc代码参预django是不能够使用models和views的。

 

缓解格局正是在greeter_server.py中(那一个文件不知情请看上边的链接)加载django,大约如下:

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图