Este proyecto consiste en una aplicación basada en microservicios desarrollada con Spring Boot. La arquitectura se compone de tres microservicios: Products, Inventory y Orders, cada uno implementando Lombok. Cada microservicio tiene su propia base de datos PostgreSQL o MySQL, alojada en contenedores Docker.
La comunicación sincronizada entre el microservicio de órdenes y el microservicio de inventario se realiza mediante WebClient (WebFlux). Este enfoque permite consultar el inventario antes de crear una orden y está respaldado por Resilience4j mediante un "Circuit Breaker".
Al crear una orden, se emite un evento en un topic de un broker, el cual se encuentra en un clúster Apache Kafka gestionado por Zookeeper. El componente Notification Service de Spring Boot se suscribe al "topic" en Kafka y permanece allí a la escucha de eventos emitidos por el microservicio de Orders.
El sistema completo está orquestado mediante Netflix Eureka para el descubrimiento de servicios, con un API Gateway para el acceso externo.
La autenticación se maneja mediante Spring Security con tokens JWT y Keycloak, este ultimo proporciona facilidad a la hora de querer crear usuarios y roles de usuario, proporcionando una capa segura para la aplicación y facil de gestionar.
La monitorización de microservicios, el seguimiento de logs y trazas se facilita mediante Zipkin, Prometheus y Grafana, proporcionando métricas clave para mejorar el rendimiento del sistema.
Lombok se ha integrado para reducir la verbosidad del código, mejorar la legibilidad y facilitar el mantenimiento del código fuente.
Debes tener instalados los siguientes elementos en tu entorno de desarrollo:
git clone https://github.com/bardolog1/Microservices-Project-Spring.git
cd Microservices-Project-Spring
Inicia las bases de datos con Docker:
docker-compose up -d db-products db-inventory db-orders db-keycloak
Inicia Keycloak, Zookeeper, Kafka, Zipkin, Prometheus & Grafana
docker-compose up -d keycloak zookeeper kafka zipkin prometheus grafana
Espera a que Keycloak se inicie y luego configura realms, clients, usuarios y roles de usuario según sea necesario.