首页 > 编程语言 > 详细

22-基于Python构建GRPC服务

时间:2021-08-30 05:12:50      阅读:11      评论:0      收藏:0      [点我收藏+]

学习案例来源

https://zhuanlan.zhihu.com/p/97893141

安装包

pip install grpcio
pip install grpcio-tools

编写proto文件

syntax = "proto3";


service Cal {
    rpc Add(AddRequest) returns (ResultReply) {}
    rpc Multiply(MultiplyRequest) returns (ResultReply) {}
}


message AddRequest {
    int32 num1 = 1;
    int32 num2 = 2;
}


message MultiplyRequest {
    int32 num1 = 1;
    int32 num2 = 2;
}


message ResultReply {
    int32 num = 1;
}

生成proto文件定义的类

python -m grpc_tools.protoc --python_out=. --grpc_python_out=. -I. test.proto
ls

编写Server

from concurrent import futures
import grpc
import SimpleCal_pb2
import SimpleCal_pb2_grpc


class CalServicer(SimpleCal_pb2_grpc.CalServicer):
    def Add(self, request, context):
        print("Add function called")
        return SimpleCal_pb2.ResultReply(num=request.num1+request.num2)

    def Multiply(self, request, context):
        print("Multiply function called")
        return SimpleCal_pb2.ResultReply(num=request.num1*request.num2)

def serve():
    server = grpc.server(futures.ThreadPoolExecutor(max_workers=5))
    SimpleCal_pb2_grpc.add_CalServicer_to_server(CalServicer(), server)
    server.add_insecure_port("[::]:50051")
    server.start()
    print("grpc sercer start...")
    server.wait_for_termination()


if __name__ == ‘__main__‘:
    serve()

编写client

import SimpleCal_pb2
import SimpleCal_pb2_grpc
import grpc


def run(n, m):
    channel = grpc.insecure_channel("localhost:50051")  # 连接上grpc服务端
    stub = SimpleCal_pb2_grpc.CalStub(channel)
    response = stub.Add(SimpleCal_pb2.AddRequest(num1=n, num2=m))
    print(f‘{n} + {m} = {response}‘)
    response2 = stub.Multiply(SimpleCal_pb2.MultiplyRequest(num1=n, num2=m))
    print(f‘{n} * {m} = {response2}‘)


if __name__ == ‘__main__‘:
    for i in range(100):
        run(2000, 304443)

22-基于Python构建GRPC服务

原文:https://www.cnblogs.com/lotuslaw/p/15200450.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!