microservices-demo/src/recommendationservice/recommendation_server.py

55 lines
1.7 KiB
Python
Raw Normal View History

2018-06-14 19:30:50 +00:00
import grpc
import demo_pb2
import demo_pb2_grpc
2018-06-14 19:45:44 +00:00
from concurrent import futures
import time
import random
2018-06-21 05:37:56 +00:00
import os
2018-06-14 19:30:50 +00:00
2018-06-14 19:45:44 +00:00
class RecommendationService(demo_pb2_grpc.RecommendationServiceServicer):
def ListRecommendations(self, request, context):
2018-06-21 06:26:32 +00:00
max_responses = 5
2018-06-14 22:31:06 +00:00
print("handling request")
2018-06-21 06:26:32 +00:00
# get list of products
cat_response = stub.ListProducts(demo_pb2.Empty())
num_prodcuts = len(cat_response.products)
indices = random.sample(range(num_prodcuts), min(max_responses, num_prodcuts))
prod_list = [str(cat_response.products[i].id) for i in indices]
print(indices, prod_list)
2018-06-14 19:45:44 +00:00
response = demo_pb2.ListRecommendationsResponse()
response.product_ids.extend(prod_list)
2018-06-14 19:45:44 +00:00
return response
if __name__ == "__main__":
2018-06-21 05:37:56 +00:00
# get port from $PORT envar
port = os.environ.get('PORT', "8080")
# get product catalog service address from $PRODUCT_CATALOG_SERVICE_ADDR envar
catalog_addr = os.environ.get('PRODUCT_CATALOG_SERVICE_ADDR', "localhost:8081")
print("product catalog address: " + catalog_addr)
print("listening on port: " + port)
2018-06-14 22:52:41 +00:00
2018-06-21 06:26:32 +00:00
# stub for product catalog service
channel = grpc.insecure_channel(catalog_addr)
stub = demo_pb2_grpc.ProductCatalogServiceStub(channel)
2018-06-14 19:45:44 +00:00
# create gRPC server
server = grpc.server(futures.ThreadPoolExecutor(max_workers=10))
# add class to gRPC server
demo_pb2_grpc.add_RecommendationServiceServicer_to_server(RecommendationService(), server)
# start server
2018-06-14 22:52:41 +00:00
server.add_insecure_port('[::]:'+port)
2018-06-14 19:45:44 +00:00
server.start()
# keep alive
try:
while True:
2018-06-14 22:31:06 +00:00
time.sleep(10000)
2018-06-14 19:45:44 +00:00
except KeyboardInterrupt:
server.stop(0)