如何解决如何使用python向gprc服务器发送图像旋转请求?
我是 grpc 的新手。我很难理解它。无论如何,我基于一个名为:image.proto
的 protobuf 文件工作Syntax = "proto3";
option java_multiple_files = true;
message NLImage {
bool color = 1;
bytes data = 2;
int32 width = 3;
int32 height = 4;
}
message NLImageRotateRequest {
enum Rotation {
NONE = 0;
NINETY_DEG = 1;
ONE_EIGHTY_DEG = 2;
TWO_SEVENTY_DEG = 3;
}
Rotation rotation = 1;
NLImage image = 2;
}
service NLImageService {
rpc RotateImage(NLImageRotateRequest) returns (NLImage);
rpc MeanFilter(NLImage) returns (NLImage);
}
我能够创建 server.py 文件和 client.py。我还从 image.proto 文件生成了 image_pb2.py,并生成了 image_pb2_grpc.py。
现在,我被困在从客户端向服务器发送图像旋转请求,并获得适当的响应。
这是我迄今为止在 client.py 中尝试过的
import grpc
# import the generated files
import image_pb2
import image_pb2_grpc
#.......
#.......SEVERAL LInes OF CODE LATER
#.......
print('Input image path is',inputfile)
print('Output path is',outputfile)
print('Mean is',mean)
print("Rotate is",rotate)
channel = grpc.insecure_channel('localhost:5000')
stub = image_pb2_grpc.NLImageServiceStub(channel)
# SEND ROTATION REQUEST IF rotate
img_rotate_request = image_pb2.NLImageRotateRequest()
stub.RotateImage(img_rotate_request,inputfile)
我不确定如何正确发送 RotateImage 请求。
下面是我的 server.py:
import sys,getopt
from google.protobuf.descriptor import EnumDescriptor
import grpc
from concurrent import futures
import time
import numpy as np
# importing grpc generated classes
import image_pb2
import image_pb2_grpc
class NLImageServiceServicer(image_pb2_grpc.NLImageServiceServicer):
def RotateImage(self,request,context):
print("Request to rotate image received")
return image_pb2._NLIMAGE()
def MeanFilter(self,context):
print("Request to filter received")
return image_pb2.NLImage()
server = grpc.server(futures.ThreadPoolExecutor(max_workers=10))
image_pb2_grpc.add_NLImageServiceServicer_to_server(NLImageServiceServicer,server)
server.add_insecure_port( host + ":" + str(port))
server.start()
print("Server started ...on " + host + ":" + port)
server.wait_for_termination()
解决方法
观察你的代码,它看起来没问题;我没有运行它。
您正确地调用了方法:stub.RotateImage
,但您没有正确地为其创建消息类型 (NLImageRotateRequest
)。它将是由 protoc
为您生成的类的实例,可能是 image_pb2.NLImageRotateRequest
,它包含 rotation
和 image
属性。 image
本身是类 image_pb2.Image
等的实例。
有关将 protobuf 与 Python 结合使用的信息,请参阅此 link,因为每种语言都是不同的,而且 Python 在创建消息的方式上有一些怪癖。
在某些时候,您需要将 inputfile
作为字节读入以填充 data
的 image
属性。
如果您还没有,请查看 grpc.io 上的 Python HelloWorld 示例。这是基本的,但它会让你开始使用 gRPC。然后查看我上面包含的链接和 Python 上的 protobuf 部分。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。