Event Horizon is a CQRS/ES toolkit for Go. Event Horizon is used in production systems but the API is not final! CQRS stands for Command Query Responsibility Segregation and is a technique where object access (the Query part) and modification (the Command part) are separated from each other. This helps in designing complex data models where the actions can be totally independent from the data output. ES stands for Event Sourcing and is a technique where all events that have happened in a system are recorded, and all future actions are based on the events instead of a single data model. The main benefit of adding Event Sourcing is traceability of changes which can be used for example in audit logging. Additionally, "incorrect" events that happened in the past (for example due to a bug) can be compensated for with an event that will make the current data "correct", as that is based on the events.

Features

  • Useful for testing and experimentation
  • One document per aggregate with events as an array
  • One document per event with an additional document per aggregate
  • An event recorder (middleware) that can be used in tests to capture some events
  • Adds distributed tracing support to event store operations with OpenTracing
  • To develop Event Horizon you need to have Docker and Docker Compose installed

Project Samples

Project Activity

See All Activity >

License

Apache License V2.0

Follow Event Horizon

Event Horizon Web Site

Other Useful Business Software
Outgrown Windows Task Scheduler? Icon
Outgrown Windows Task Scheduler?

Free diagnostic identifies where your workflow is breaking down—with instant analysis of your scheduling environment.

Windows Task Scheduler wasn't built for complex, cross-platform automation. Get a free diagnostic that shows exactly where things are failing and provides remediation recommendations. Interactive HTML report delivered in minutes.
Download Free Tool
Rate This Project
Login To Rate This Project

User Reviews

Be the first to post a review of Event Horizon!

Additional Project Details

Operating Systems

Linux, Mac, Windows

Programming Language

Go

Related Categories

Go Frameworks, Go Distributed Tracing Tool

Registered

2023-02-03