2016-08-12 15:48:28 -07:00
|
|
|
from simple_pb2 import *
|
2019-08-20 17:47:32 +02:00
|
|
|
import simple_pb2_grpc
|
2016-08-12 15:48:28 -07:00
|
|
|
from uuid import uuid4
|
2019-08-20 17:47:32 +02:00
|
|
|
from concurrent import futures
|
2016-08-12 15:48:28 -07:00
|
|
|
import random
|
|
|
|
import Queue
|
|
|
|
import grpc
|
|
|
|
|
|
|
|
print "Starting python server"
|
|
|
|
|
|
|
|
done_queue = Queue.Queue()
|
|
|
|
|
2019-08-20 17:47:32 +02:00
|
|
|
class SimpleServiceServer(simple_pb2_grpc.SimpleServiceServicer):
|
2016-08-12 15:48:28 -07:00
|
|
|
def done(self, request, context):
|
|
|
|
global server
|
|
|
|
done_queue.put_nowait(())
|
|
|
|
|
|
|
|
return SimpleServiceDone()
|
|
|
|
|
|
|
|
def normalCall(self, request, context):
|
|
|
|
return SimpleServiceResponse(response = "NormalRequest", num = sum(request.num))
|
|
|
|
|
|
|
|
def clientStreamingCall(self, requests, context):
|
|
|
|
cur_name = ""
|
|
|
|
cur_sum = 0
|
|
|
|
for request in requests:
|
|
|
|
cur_name += request.request
|
|
|
|
cur_sum += sum(request.num)
|
|
|
|
return SimpleServiceResponse(response = cur_name, num = cur_sum)
|
|
|
|
|
|
|
|
def serverStreamingCall(self, request, context):
|
|
|
|
for num in request.num:
|
|
|
|
yield SimpleServiceResponse(response = request.request, num = num)
|
|
|
|
|
|
|
|
def biDiStreamingCall(self, requests, context):
|
|
|
|
for request in requests:
|
|
|
|
yield SimpleServiceResponse(response = request.request, num = sum(request.num))
|
|
|
|
|
2019-08-20 17:47:32 +02:00
|
|
|
server = grpc.server(futures.ThreadPoolExecutor(max_workers=1))
|
|
|
|
simple_pb2_grpc.add_SimpleServiceServicer_to_server(SimpleServiceServer(), server)
|
2016-08-12 15:48:28 -07:00
|
|
|
server.add_insecure_port('[::]:50051')
|
|
|
|
server.start()
|
|
|
|
|
|
|
|
done_queue.get()
|