This repository contains a starter pack for Event Sourcing in Java It is a production grade starting point for your own event sourced application. The starter pack has everything you need to get started with event sourcing, including an event store, a projection store, and an event bus.
This starter pack implements a simple example for a Cooking Club Membership. But you're meant to replace this example with your own application.
To run this application you need Docker. Once you have Docker installed, please clone the code,
navigate to the local-development/scripts
folder.
git clone git@github.com:ambarltd/event-sourcing-java.git
cd event-sourcing-java/local-development/scripts/linux # if you're on linux
cd event-sourcing-java/local-development/scripts/mac # if you're on mac
./dev_start.sh # start docker containers
./dev_demo.sh # run demo
You can then open your browser to:
- http://localhost:8080 to ping the backend
- http://localhost:8081 to view your event store
- http://localhost:8082 to view your projection store
Assuming you know event sourcing theory, developing on this application will feel very natural. Otherwise, don't worry - Ambar offers a free 1 day Event Sourcing course here.
To get a quick understanding of how this application works, please read the domain code in src/main/java/eventsourcing/domain/
, the abstractions provided in src/main/java/eventsourcing/common/
, and the README files also in src/main/java/eventsourcing/common/
. With that reading done, here's a full picture:
src/main/java/eventsourcing/domain/
: where you define aggregates, events, commands, queries, projections, and reactions. You will spend most of your time here.src/main/java/eventsourcing/common/
: a set of event sourcing abstractions. You will rarely need to edit files here, except for having to update theSerializer
andDeserializer
classes insrc/main/java/eventsourcing/domain/common/serializedevent/
whenever you add or remove events.- Dependency injection and routes are defined with annotations, relying on Spring.
When developing your application for the fist time, we recommend you keep the Cooking Club Membership code as an example you can quickly navigate to. Once you have implemented several commands, queries, projections, and reactions, delete the Cooking Club Membership code. This will require you to delete its code in Domain
, and serialization logic in Common/serializedEvent
.
Whenever you build a new feature, you might want to restart the application, or even delete the event store and projection store. We have provided scripts to help you with that.
cd event-sourcing-java/local-development/scripts/linux # if you're on linux
cd event-sourcing-java/local-development/scripts/mac # if you're on mac
./dev_start.sh # starts / restarts the application.
./dev_start_with_data_deletion.sh # use this if you want to delete your existing event store, and projection db, and restart fresh.
./dev_shutdown.sh # stops the application
To deploy this application to a production environment, you will simply need to build the code into a docker image, and deploy it to your cloud provider. We have provided infrastructure starter packs for various clouds in this repository.
If you get stuck, please feel free to ask questions in the #event-sourcing channel of our Slack community. Or if you need further help like a free private walkthrough, simply book one here.