SuuCat is a sample containerized application consisting of several microservices. Its purpose is to use microservice patterns in practice.
Development is still in progress.
Saga Orchestration with MassTransit and RabbitMq
Eventual Consistency with Integration Events using RabbitMq
Authorization and Authentication with IdentityServer
Distributed Logging with ElasticSearch, Kibana and SeriLog
Resiliency and Fault Tolerance with Polly
Distributed Tracing with Jaeger and OpenTelemetry
Metrics to Monitor Microservices with OpenTelemetry and Prometheus
⭐ Star this project on GitHub - it's the first step to become a SuuCat supporter!
Contributions are welcome! If you find a bug or have an idea for a new feature, please open an issue or submit a pull request.
- Eventual Consistency with Change Data Capture(CDC) and Outbox pattern (Debezium)
- Outbox/Inbox patterns for inter-service communication
- Integration Tests with Consumer Driven Contracts (Pact)
Ocelot
Identity Server
Masstransit Saga
Clean Architecture
Health Monitoring
RabbitMQ