This repository showcases a sample implementation of a message broker using .NET technologies. It provides a demonstration of how to build a distributed messaging system using popular message broker patterns, along with Docker images, Kubernetes deployment, and Helm charts.
- Demonstrates the use of a message broker for decoupling and asynchronous communication between microservices.
- Implements common messaging patterns such as publish-subscribe, request-reply, and event-driven architecture.
- Utilizes popular message broker technologies, including RabbitMQ or Apache Kafka, to showcase different options and configurations.
- Provides example code and documentation for setting up message producers, consumers, and message handlers.
- Includes sample microservices that communicate through the message broker, highlighting the benefits of loose coupling and scalability.
- Offers insights and best practices for building resilient, scalable, and fault-tolerant distributed systems.
- Includes Dockerfiles and Docker Compose configuration for containerizing the sample microservices.
- Provides Kubernetes deployment manifests and Helm charts for deploying the microservices to a Kubernetes cluster.
- Demonstrates how to scale and manage the message broker infrastructure using Kubernetes and Helm.
- Seamless integration of Rust implementation for Order functionality with the existing infrastructure without requiring any modifications to the database schema or the message broker configuration.
- Configure OpenTelemetry to export traces directly to Jaeger.
- Supports ArgoCD using Helm charts.
Application consists of several .NET microservices all communicating with RabbitMQ:
- CatalogAPI provides basic API for querying products. Data persisted in mongo CatalogDb.
- CustomerAPI basic authentication microservice that allows to register, log in and delete users. Data persisted in mongo CustomerDb.
- Notifications observes events on the message broker and sends user specific events to clients.
- OcelotAPIGateway basic Gateway microservice that stands in front of all microservices.
- OrderAPI provides basic API for managing orders. It interfaces with MongoDB for data storage and RabbitMQ for message queuing, and it exposes a RESTful API for managing orders. Data persisted in mongo OrderDb.
- OrderGrpc internal microservice for managing orders via GRPC instead of REST API, used by OrderProcessor.
- OrderProcessor main ordering business logic, uses message broker to produce and consume messages to and from other services.
- PaymentService basic payment microservice, consumes and produces message from the message broker. Data persisted in mongo PaymentDb.
- Shipment basic shipment microservice, consumes and produces message from the message broker. Data persisted in mongo ShipmentDb.
- ShoppingCartAPI manages user shopping carts via REST API. Data persisted in mongo ShoppingCartDb.
- Warehouse basic warehouse microservice, consumes and produces message from the message broker.
- WarehouseAPI provides REST API to get products stock levels. Used by WebUI. Data persisted in mongo WarehouseDb.
- WebUI main UI application built with .NET Razor pages. Uses WebUIAggregator and OcelotAPIGateway. Supports SignalR notifications to browser clients.
- WebUIAggregator aggregates requests to multiple microservices. Used by WebUI.
- roderapi Rust implementation of OrderAPI seamlessly integrated with the existing infrastructure without requiring any modifications to the database schema or the message broker configuration. This demonstrates the interoperability and flexibility of the system architecture, allowing developers to leverage different programming languages while maintaining compatibility with the existing ecosystem.
You can check the data model and other sagas in .
You can run this sample in 5 different ways:
- Run .NET apps locally with RabbitMQ and Mongo running in docker.
- Multi-Container .NET apps, RabbitMQ and Mongo running in Kubernetes.
- Using .NET Aspire.
- Using a Helm chart.
- Using ArgoCD.
Run with Powershell script 01_run_local.ps1. This will start:
- RabbitMQ and Mongo in Docker.
- All .NET microservices will get started in separate windows.
- http://localhost:8011/ will be opened in your browser's window.
- Wait for all the services to start up and hit Refresh. You should see the main page.
- Run with Powershell script 03_start_minikube.ps1 to start minikube. Wait for the script to complete.
- Run with Powershell script 04_run_minimal_k8s.ps1 to deploy docker images to Kubernetes.
- Observe the deployment in opened Kubernetes dashboard. Wait for all the pods change the status to Running.
- Main WebUI service and Jaeger UI are going to be exposed by the minikube.
- Run with Powershell script 04_stop_k8s.ps1 to delete the deployment.
- Make sure you have docker running locally
- Execute in
\eshop-aspire.AppHost
dotnet run
- Aspire dashboard page should be opened
- Run with Powershell script 03_start_minikube.ps1 to start minikube. Wait for the script to complete.
- Run with Powershell script 05_run_minimal_helm.ps1 to install helm chart.
- Observe the deployment in opened Kubernetes dashboard. Wait for all the pods change the status to Running.
- Main WebUI service is going to be exposed by the minikube.
- Stop it by running 05_stop_helm.ps1.
|-----------|-------|-------------|---------------------------|
| NAMESPACE | NAME | TARGET PORT | URL |
|-----------|-------|-------------|---------------------------|
| default | webui | http/80 | http://192.168.49.2:32289 |
|-----------|-------|-------------|---------------------------|
* Starting tunnel for service webui.
|-----------|-------|-------------|------------------------|
| NAMESPACE | NAME | TARGET PORT | URL |
|-----------|-------|-------------|------------------------|
| default | webui | | http://127.0.0.1:62184 |
|-----------|-------|-------------|------------------------|
- Run with Powershell script 05_stop_helm.ps1 to uninstall the helm chart.
- Run with Powershell script 03_start_minikube.ps1 to start minikube. Wait for the script to complete.
- Run with Powershell script 06_run_argocd.ps1 to start ArgoCD deployment.
ArgoCD dashboard is going to be opened in https://localhost:8080/. Main WebUI service is going to be exposed by the minikube. You can as well observe deployment in minikube dashboard inside argocd-eshop-minimal namespace. You can stop the deployment and delete pods with 07_stop_argocd.ps1 Powershell script.
Building Microservices, 2nd Edition. Sam Newman. Message Brokers
Kubernetes: Host Multi-Container ASP.NET Core app to Multiple Pods
How to use Helm for ASP.NET Core with Kubernetes
Creating a Helm chart for an ASP.NET Core app
Difference between pushing a docker image and installing helm image
How to create a helm chart to deploy multiple applications using the same value.yaml file
RabbitMQ: How to combine a task queue and a fanout/routing/topic models