microservices-demo/src/recommendationservice/recommendation_server.py

44 lines
1.3 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-14 22:31:06 +00:00
print("handling request")
2018-06-14 19:45:44 +00:00
response = demo_pb2.ListRecommendationsResponse()
2018-06-14 22:31:06 +00:00
prod_list = []
for i in range(5):
prod_list.append(str(random.randint(1,100)))
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-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)