This project is created to get experience on Microservices With Netflix OSS. This is a simple project by coded imperative programming with simple business requirements.
- Accounts : This microservice is responsible for managing accounts. An account could be buyer, seller or an backoffice account but there is only buyer account.
- Products : This microservice is responsible for managing products.
- Orders : This microservice is responsible for managing orders. It doesn't know anything about account and product except id.
- Backoffice: This microservice is provides endpoints for backoffice ui.
Backoffice microservice has an endpoint with path "/api/v1/backoffice/orders". This endpoint return a list of orders with name of product and account. It connects accounts, products and orders microservices via Feign.
Service | EndPoint | Method | Description |
---|---|---|---|
Accounts | /api/v1/accounts/{id} | GET | Return detail of specified account |
Accounts | /api/v1/accounts | GET | Return details of all acounts |
Products | /api/v1/products/{id} | GET | Return detail of specified product |
Products | /api/v1/products | GET | Return details of all products |
Orders | /api/v1/orders/{id} | GET | Return detail of order |
Orders | /api/v1/orders | GET | Return details of orders |
Backoffice | /api/v1/backoffice/orders | GET | Return orders with product name and account name |
Service | EndPoint |
---|---|
Accounts | /account/api/v1/accounts/{id} |
Accounts | /account/api/v1/accounts |
Products | /product/api/v1/products/{id} |
Products | /product/api/v1/products |
Orders | /order/api/v1/orders/{id} |
Orders | /order/api/v1/orders |
Backoffice | /backoffice/api/v1/backoffice/orders |
URI for gateway : http://localhost:8762
- Netflix Eureka is used for discovery service.
- Netflix Ribbon is used for client side load-balancing.
- Netflix Zuul is used for gateway.
- >mvn clean package : to build
- >docker-compose up --build : build docker images and containers and run containers
- >docker-compose stop : stop the dockerized services
- Each maven module has a Dockerfile.
In docker-compose.yml file:
- Accounts Service : 2222 port is mapped to 7500 port of host
- Products Service : 2222 port is mapped to 7501 port of host
- Orders Service : 2222 port is mapped to 7502 port of host
- Backoffice Service : 2222 port is mapped to 7503 port of host
- Eureka Discovery Service : 8761 port is mapped to 8761 port of host
- Zuul Gateway Service : 8762 port is mapped to 8762 port of host