I am starting to build a Microservice API Gateway, and I am using Spring Cloud Zuul to help me with the routing. But some calls to the Gateway API will need multiple requests to different services.
Lets say I have 2 services: Order Details Service and Delivery Service. I want to have a Gateway endpoint GET /orders/{orderId} that makes a call to Order Details service and then Delivery Service and combine the two to return full Order details with delivery. Is this possible with the routing of Zuul(maybe filters?) or should I make these by hand(create a controller specifically for these kinds of requests) using something like RestTemplate to make the calls?
You can avoid that complication and forward request from your Gateway
to the Order service
to make an order, than make HTTP
request from Order service
to Delivery service
to make the delivery. By nature those entities work like that. And don't worry about the speed, it is extremely fast.
That is in a first place, in your case, if you want to get the order details, with delivery details, that should go in the same manner. Maybe even your order service should persist some of delivery details in its database. We were doing it like that, you should avoid redundant data, but sometimes it make sense.
Here is the chart of making the order:
Make sense?