22-基于Python构建GRPC服务

学习案例来源

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)

作者:lotuslaw

出处:https://www.cnblogs.com/lotuslaw/p/15200450.html

版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。

posted @   lotuslaw  阅读(54)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
历史上的今天:
2020-08-28 N皇后问题
more_horiz
keyboard_arrow_up light_mode palette
选择主题
点击右上角即可分享
微信分享提示