Skip to content

Latest commit

 

History

History
52 lines (33 loc) · 3.98 KB

README.md

File metadata and controls

52 lines (33 loc) · 3.98 KB

EDA Quickstarts

UNDER CONSTRUCTION - Updated 07/28/2022

This project includes a set of getting started code templates for your event driven projects.

The approach is to use one of the different starting code folder to help implementing your own event driven solution. Part of the IBM Garage methodology is to apply event storming and domain driven design to start your project on good track. Once you have discovered events, aggregates, commands and bounded contexts the next step is to start your microservice with all the needed artifacts to build, run locally and then deploy to OpenShift.

We try to use the same structure for code to support Domain Driven Design practices as resource, service, domain, infrastructure, api...

The main project includes the environment folder which supports different deployments:

  • to run Strimzi Kafka and Apicurio locally on your laptop using docker compose
  • to deploy strimzi on OpenShift with kustomize
  • to deploy event streams on OpenShift with kustomize see the eda-gitops-catalog

Each project includes:

  • Code template based on the same OrderEntity management
  • Github action workflow to build with maven, build jvm docker image and push the image to an image registry
  • Kustomize folder for yamls to deploy to OpenShift cluster which could be included in a GitOps project.

A template of GitOps project is in the eda-quickdtart-gitops repository with the 2 reactive messaging services configured and deployed.

kam bootstrap --service-repo-url https://github.com/jbcodeforce/eda-demo-order-ms --gitops-repo-url https://github.com/jbcodeforce/eda-demo-order-gitops --image-repo quay.io/ibmcase/eda-order-rms --output eda-demo-order-gitops --prefix edademo --push-to-git=true --git-host-access-token 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

Java templates

We are adopting Quarkus (current version is 2.5) as our main Java Microprofile framework, for the development experience, and the excellent performance to start in Kubernetes.

Here are the project

Still under construction:

Other projects that could be used as template / source of inspiration: