grpc在django中的使用

要调用RPC接口,python提供了1个框架grpc,那是google开源的

gRPC 简介:

gRPC 是一款高质量、开源的 RPC 框架,产自 谷歌(Google),基于 ProtoBuf
连串化协议进行开垦,帮助种种语言(Golang、Python、Java等),本篇只介绍
Python 的 gRPC 使用。因为 gRPC 对 HTTP/二 协议的支撑使其在 Android、IOS
等客户端后端服务的付出领域有所突出的前景。gRPC
提供了1种简易的艺术来定义服务,同时客户端能够丰富利用 HTTP/2 stream
的特色,从而推动节省带宽、下跌 TCP 的连日次数、节省CPU的行使等。

近年来在做微服务那1块,后端与java合营,本身是python的,所以思虑动用grpc,一点思索是grpc是http二.0,另壹些思量是老概况求的:)

rpc相关文书档案:

安装:

  1. gRPC 的安装:

$ pip install grpcio

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

$ pip install protobuf

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

$ pip install grpcio-tools


https://grpc.io/docs/tutorials/basic/python.html

实践:

上面大家使用 gRPC
定义三个接口,该接口完毕对传播的数额进行大写的格式化处理。

  • 制造项目 python demo 工程:
![](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 接口
  • 定义 gRPC 接口:

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

$ python -m grpc_tools.protoc -I. –python_out=.
–grpc_python_out=. ./data.proto #在 example
目录中实施编写翻译,会扭转:data_pb2.py 与 data_pb2_金沙js333娱乐场,grpc.py

  • 实现 server 端:

#! /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()
  • 实现 client 端:

#! /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,WO凯雷德LD!” ,证明gRPC 接口定义成功

  • 交流可以加 QQ 群:3972343八伍
  • 抑或 QQ 扫码入群:

金沙js333娱乐场 1

qq群.jpg

起来尝试是在python脚本中与java对接接口,平日官方文书档案的一顿学习,成功调通了接口

 

https://grpc.io/docs/quickstart/python.html
然则在教程里clone的不行项目实际是大,不显明哪些是需求的,经过测试后交由供给的:

内需安装的python包如下:

  • grpcio==1.4.0
  • grpcio-tools==1.4.0
  • xxx.proto 没有错,只须要如此二个文本
  • 编译xxx.proto的命令

1.grpc安装

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

pip
install grpcio

此处解释一下,python(不解释) -m(也不解释)
grpc_tools.protoc(下面安装的叁方)
-I./protos(标志当前目录下的protos文件夹,xxx.proto须求在这几个文件夹中)
–python_out=.(当前目录生成输出文件)
–grpc_python_out=.(当前目录生成grpc文件)
./protos/xxx.proto(xxx.proto的相对路线)

 

在布署好grpc的xxx.proto之后要保管java那边的那个文件要壹致(并不是任何,service开端须要完全一样)

2.grpc的python
protobuf相关的编译工具

运营命令后会生成xxx_pb2.py 和
xxx_pb2_grpc.py多少个文件,接下去重点来了(拍桌子)

pip install
grpcio-tools

本身既想用django的model又想用grpc该如何是好吧,django是二个劳动,grpc是多个劳动,间接暴力把grpc代码到场django是不能使用models和views的。

 

消除方式就是在greeter_server.py中(这么些文件不驾驭请看下面的链接)加载django,大约如下:

3.protobuf相关python依赖库

import os
from concurrent import futures

import grpc
import time

import bus_pb2
import bus_pb2_grpc

import django

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "xxx.settings")

django.setup()

from enterprise.views import enterprise_list, add_enterprise

_ONE_DAY_IN_SECONDS = 60 * 60 * 24


class Greeter(bus_pb2_grpc.BusInfoServicer):
    def BusMethod(self, request, context):
        if request.method == 'e':
            response = enterprise_list(request)
            return bus_pb2.BusReply(data=response['data'], code=response['code'], message=response['msg'])
        elif request.method == 'a':
            response = add_enterprise(request)
            return bus_pb2.BusReply(message=response['msg'])
        return bus_pb2.BusReply(message='')


if __name__ == '__main__':
    server = grpc.server(futures.ThreadPoolExecutor(max_workers=10))
    bus_pb2_grpc.add_BusInfoServicer_to_server(Greeter(), server)
    server.add_insecure_port('0.0.0.0:50051')
    server.start()
    try:
        while True:
            time.sleep(_ONE_DAY_IN_SECONDS)
    except KeyboardInterrupt:
        server.stop(0)

发表评论

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