DDD en Java

DDD en Java

Crea paso a paso tu aplicación Java siguiendo Domain-Driven Design. Desde la estructura inicial de carpetas, hasta la implementación de los mappings con base de datos, pasando por la configuración de los tests de aceptación y unitarios, publicación de eventos, y mucho más 🤟
COURSE DESCRIPTION

💸 ¡Primera lección disponible sin registro!

Curso completo para crear aplicaciones en Java siguiendo los patrones tácticos y estratégicos de DDD

Qué veremos en este curso de Domain-Driven Design en Java

  • [Gratis] 📖 Creación del proyecto: Bounded Context y Submodules – Estructura carpetas
    • 🎥 Bienvenida al curso: Objetivos, ¿qué aprenderás?
    • 🎥 Estructura de carpetas: DDD en Java
    • 🎥 Monorepo multiproyecto con Gradle
  • 📖 Health check de la aplicación: Nuestro primer endpoint
    • 🎥 Crear Endpoint de health check
    • 🎥 Añadir tests de aceptación con Spring Boot Runner
  • 📖 Desarrollo Outside-in: Implementación del caso de uso para crear curso
    • 🎥 Implementación del test de aceptación y controller
    • 🎥 Implementación del test unitario y caso de uso
    • 🎥 Implementación del repositorio en memoria y test de integración
  • 📖 Modelando el dominio: Agregado Course
    • 🎥 Utilizando objetos Request y Response para comunicarnos con el Application Service
    • 🎥 Refacoting a UUIDs como identificadores
    • 🎥 Value Objects: Immutabilidad y tips para agilizar desarrollo
  • 📖 Modelando el dominio: Implicaciones en tests
    • 🎥 Patrón ObjectMother para nuestros tests
    • 🎥 Tests más semánticos
  • 📖 Guardar en base de datos con Hibernate
    • 🎥 Integración de Hibernate
    • 🎥 Mapeo de modelos en Hibernate
    • 🎥 Implementación del repositorio para MySQL y test de integración
    • 🎥 Discriminator Map con Hibernate
  • 📖 Eventos de dominio en memoria con Spring Events: Incrementar el total de cursos
    • 🎥 Integración de Spring Events
    • 🎥 Publicación y suscripción de eventos de dominio y test de aceptación
    • 🎥 Idempotencia al consumir eventos: Implementación del caso de uso y test unitario
  • 📖 Testeando “parcialmente”: Agregados con eventos de dominio
    • 🎥 Testeando guardar en el repositorio con eventos de dominio en el agregado
    • 🎥 Alternativa: publicar eventos desde agregados
  • 📖 Eventos de dominio asíncronos – MySQL
    • 🎥 Guardado de eventos de dominio en MySQL
    • 🎥 Consumidor / worker de eventos de dominio
    • 🎥 Polling de base de datos para recuperar eventos
  • 📖 Publicar eventos de dominio asíncronos y escalables utilizando RabbitMQ
    • 🎥 Publicar eventos en RabbitMQ desde Java
    • 🎥 Añadiendo un fallback a la publicación de eventos de dominio
  • 📖 Consumir eventos con RabbitMQ
    • 🎥 Consumir eventos en RabbitMQ desde Java
    • 🎥 Gestión de reintentos y Dead Letter
    • 🎥 Generando la configuración del RabbitMQ al deployar
  • 📖 CQRS
    • 🎥 Integración de Command y Query Bus
    • 🎥 Refactoring añadiendo CQRS a Arquitectura Hexagonal
  • 📖 Bounded Contexts y módulos
    • 🎥 Crear módulo de Notificaciones
    • 🎥 Promocionar Módulo Notificaciones a Bounded Context de Retención
  • 📖 Frontend web
    • 🎥 Integración con sistema de templating
    • 🎥 Mostrar contador de cursos vía query desde Controller
    • 🎥 Crear curso: Dónde ubicar validaciones de comandos
  • 📖 Backoffice
    • 🎥 Listado de cursos: Mantener proyección de cursos
    • 🎥 Filtrado de elementos: Patrón Criteria/Specification
  • 📖 Optimizando rendimiento en Read Model – Moviéndonos a NoSQL: Elasticsearch al rescate
    • 🎥 Primera importación de datos a Elasticsearch
    • 🎥 Mantener sincronizada la proyección de Elasticsearch
    • 🎥 Patrón Criteria/Specification con Elasticsearch
  • 📖 Optimizando rendimiento – Más allá de Elasticsearch: Optimizaciones MySQL, caching web y más
  • 📖Autorización
  • 📖Preguntas frecuentes
  • 📖 Conclusión y siguientes pasos

251

Peso 7.6GB

7 Descargas