Architecture
Mission Control has a micro-service architecture with a shared data source with multiple deployment models.
- CLI
- Kubernetes (Helm Chart)
- SaaS
Communication Model
Communication between services happen in 3 ways:
- Database - A shared database with interface library enables services to query the data owned by other services by directly hitting the database using an interface provided by a shared library
- Messaging - A postgres based message bus is used, database triggers insert events into queues which are then consumed by various services
- HTTP/REST - This model is primarily used when the service need to interact with services outside the DB (e.g. the APM hub needs to connect to log stores to retrieve logs)
Shared Data Source
All microservices use a shared database and model via the https://github.com/flanksource/duty project, this provides the following benefits:
- Each microservice can update the database directly with full referential integrity between tables owned by other services
Kubernetes & Gitops
Mission control is kubernetes-native with all configuration being possible by Custom Resource Definition (CRD's)
The single source of truth is still the database, the operators only function is to synchronize CRD's into the database and update the CRD status periodically.