nashtech-garage / yas

YAS: Yet Another Shop, a sample microservices project in Java
MIT License
1.61k stars 420 forks source link
docker ecommerce hacktoberfest java keycloak kubernetes microservices sample-project shop spring-boot

YAS: Yet Another Shop

YAS is a pet project aim to practice building a typical microservice application in Java

Gitleaks-check storefront-ci storefront-bff-ci backoffice-ci backoffice-bff-ci product-ci media-ci cart-ci customer-ci rating-ci location-ci order-ci inventory-ci tax-ci search-ci promotion-ci payment-ci payment-paypal-ci webhook-ci

Tentative technologies and frameworks

Local development architecture

Yas - local development architecture

Getting started with Docker Compose

  1. Get the latest source code
  2. Add the following records to your host file:
    127.0.0.1 identity
    127.0.0.1 api.yas.local
    127.0.0.1 pgadmin.yas.local
    127.0.0.1 storefront
    127.0.0.1 backoffice
    127.0.0.1 loki
    127.0.0.1 tempo
    127.0.0.1 grafana
    127.0.0.1 elasticsearch
    127.0.0.1 kafka
    127.0.0.1 akhq
  3. Open terminal of your choice, go to yas directory, run docker compose up, wait for all the containers up and running

Warning: To run all the containers, you need a minimum of 16GB of RAM. Otherwise, you can only run the core services with this command docker compose -f docker-compose.yml up

  1. All the containers up and running then we start source connectors by run script, open any terminal window... go to the YAS root folder and type: ./start-source-connectors.sh
  2. Open your browser, now you can access the websites via http://storefront/; http://backoffice/ login with admin/password

Note: For the first run, the storefront and the backoffice might not work as expected. Stop all the containers (Ctrl + C) and run docker compose up again.

You might also want to explore:

  1. http://pgadmin.yas.local/. Account login: admin@yas.com / admin. Register a server: postgres, port 5432, username admin, password admin. The Postgresql server is also exposed to the host machine: servername: localhost, port: 5432, username: admin, password: admin
  2. http://api.yas.local/swagger-ui/ for all the REST API document of all the services
  3. http://identity/ for Keycloak console, account admin/admin
  4. http://grafana/ for observability: log, trace, matrix
  5. http://elasticsearch/ for calling Elasticsearch APIs

About docker-compose files

  1. docker-compose.yml for all core services
  2. docker-compose.search.yml for search service
  3. docker-compose.o11y.yml for observability services

Deploy to Kubernetes

https://github.com/nashtech-garage/yas/tree/main/k8s/deploy

Documentation

Contributing

By contributing, you agree that your contributions will be licensed under MIT License.

Screenshots

Backoffice & Storefront Observability
Yas Backoffice Yas Storefront Yas Swagger Yas Grafana Tracing Yas Grafana Metrics