对python调用RPC接口的实例详解
要调用RPC接口,python提供了一个框架grpc,这是google开源的
rpc相关文档:
https://grpc.io/docs/tutorials/basic/python.html
需要安装的python包如下:
1.grpc安装
pipinstallgrpcio
2.grpc的pythonprotobuf相关的编译工具
pipinstallgrpcio-tools
3.protobuf相关python依赖库
pipinstallprotobuf
4.一些常见原型的生成python类的集合:
pipinstallgoogleapis-common-protos
编译protobuf文件:使用以下命令生成Python代码:
python3-mgrpc_tools.protoc-I<目标路径目录>--python_out=.--grpc_python_out=<目标文件所在目录路径><目标文件data.proto>
python3-mgrpc_tools.protoc-I.--python_out=.--grpc_python_out=.data.proto
注意:protobuf文件,为定义服务接口代码文件,这里是data.proto
会生成:data_pb2.py与data_pb2_grpc.py
data_pb2.py是服务接口映射
data_pb2_grpc.py方法映射
protobuf内容示例:
syntax="proto3"; packagegrpcDemo; messageHelloRequest{ stringname=1; } messageHelloReply{ stringmessage=1; } servicegRPC{ rpcSayHello(HelloRequest)returns(HelloReply){} }
接口调用内容示例:
#-*-coding:utf-8-*- importgrpc importdata_pb2,data_pb2_grpc _HOST='localhost' _PORT='8080' defrun(): conn=grpc.insecure_channel(_HOST+':'+_PORT) client=data_pb2_grpc.gRPCStub(channel=conn) response=client.SayHello(data_pb2.HelloRequest(name='hello,world!')) print("received:"+response.text) if__name__=='__main__': run()
以上这篇对python调用RPC接口的实例详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。