Silverback.Storage.Relational
                              
                            
                                5.0.0-beta.15
                            
                        
                            
                                
                                
                                    Prefix Reserved
                                
                            
                    See the version list below for details.
dotnet add package Silverback.Storage.Relational --version 5.0.0-beta.15
NuGet\Install-Package Silverback.Storage.Relational -Version 5.0.0-beta.15
<PackageReference Include="Silverback.Storage.Relational" Version="5.0.0-beta.15" />
<PackageVersion Include="Silverback.Storage.Relational" Version="5.0.0-beta.15" />
<PackageReference Include="Silverback.Storage.Relational" />
paket add Silverback.Storage.Relational --version 5.0.0-beta.15
#r "nuget: Silverback.Storage.Relational, 5.0.0-beta.15"
#:package Silverback.Storage.Relational@5.0.0-beta.15
#addin nuget:?package=Silverback.Storage.Relational&version=5.0.0-beta.15&prerelease
#tool nuget:?package=Silverback.Storage.Relational&version=5.0.0-beta.15&prerelease
Silverback is a powerful, elegant, and feature-rich message bus for .NET, designed to simplify asynchronous messaging, event-driven architectures, and microservice communication. With seamless integration for Apache Kafka and MQTT, it offers robust features for reliability, consistency, and scalability.
Whether you're building a small microservice, a large-scale enterprise solution, or anything in between, Silverback provides the tools to make messaging effortless and reliable.
Why Choose Silverback?
Silverback is designed for serious workloads, offering enterprise-grade capabilities with a rich feature set optimized for performance, resilience, and scalability.
Key Features
๐ Powerful Message Bus
A simple but powerful in-memory message bus enables seamless communication between components, featuring Rx.NET support for reactive programming.
๐ Seamless Message Broker Integration
Silverback makes it easy to integrate with Kafka and MQTT, providing a streamlined and developer-friendly API to build event-driven architectures with minimal setup and configuration.
๐ Kafka-Optimized Messaging
Unlike generic messaging libraries, Silverback is built specifically for Kafka, leveraging its unique capabilities for high-throughput, exactly-once semantics, and partitioned processing. While Silverback also supports MQTT, Kafka is a first-class citizen, and the framework is highly optimized to take full advantage of its power.
๐ค Transactional Outbox
Ensures message consistency by linking database transactions with messaging, preventing message loss and guaranteeing atomicity.
โ ๏ธ Advanced Error Handling
Define flexible strategies to retry, skip, or move messages based on custom policies, ensuring robustness in failure scenarios.
๐ฆ Batch Processing & Chunking
Enhances efficiency by processing messages in bulk or splitting large messages into smaller chunks, which are automatically reassembled on the receiving end.
โก Domain-Driven Design (DDD) Support
Automates domain event publishing when entities are persisted, ensuring seamless integration with message brokers for event-driven workflows.
โ
 Exactly-Once Processing
Ensures each message is consumed and processed exactly once, preventing duplicate processing and maintaining data integrity.
๐ Distributed Tracing
Leverages System.Diagnostics for full visibility into message flow and distributed transaction tracking.
๐งช Testability
Provides in-memory mocks for Kafka and MQTT, along with powerful helpers for efficient unit testing.
โจ And much more!
Silverback is highly extensible, making it the go-to messaging framework for .NET developers who want to harness Kafkaโs full potential while maintaining flexibility for other brokers.
Discover more in the project's website.
Project Status
Continuous Build
Sonar Build
Quality Metrics
Activity
Setting Up Silverback
Silverback is designed as a modular framework, allowing you to include only the components you need. This guide walks you through selecting the right packages and configuring the basics to get started.
Adding the Required Packages
Core Packages
- Silverback.Core โ The essential package, including the message bus and fundamental messaging components.
- Silverback.Core.Model โ Enhances CQRS and event-driven architectures with improved semantics.
Message Broker Integration
If you need to integrate with a message broker, choose the appropriate package:
- Silverback.Integration.Kafka โ Adds Kafka support (implicitly includes Silverback.Core).
- Silverback.Integration.Mqtt โ Adds MQTT support (implicitly includes Silverback.Core).
Additional Features
- Silverback.Core.Rx โ Enables Rx.NET integration, allowing observables from the message bus stream.
- Silverback.Newtonsoft โ Supports serialization using Newtonsoft.Json instead of System.Text.Json.
- Silverback.Kafka.SchemaRegistry โ Provides integration with Schema Registry for Protobuf, Avro, or JSON serialization with schema support.
Storage Options
Certain Silverback features rely on a storage mechanism. Choose the appropriate package based on your needs:
- Silverback.Storage.PostgreSql โ Optimized for PostgreSQL, leveraging advisory locks.
- Silverback.Storage.Sqlite โ A lightweight option, ideal for testing.
- Silverback.Storage.EntityFramework โ Works with Entity Framework, supporting all EF-compatible relational databases.
- Silverback.Storage.Memory โ An in-memory storage option, useful for testing.
Testing Support
For unit testing message-driven applications, you can use in-memory broker mocks:
- Silverback.Integration.Kafka.Testing โ Provides an in-memory Kafka mock, simulating partitioning, offsets management, and other broker behaviors.
- Silverback.Integration.Mqtt.Testing โ Provides an in-memory MQTT mock to test MQTT-related logic.
Usage
Have a look at the project's website for usage details, API documentation and samples.
Contributing
You are encouraged to contribute to Silverback! Please check out the how to contribute guide for guidelines about how to proceed.
License
This code is licensed under MIT license (see LICENSE file for details)
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
- 
                                                    net8.0- Confluent.Kafka (>= 2.8.0)
- JetBrains.Annotations (>= 2024.3.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.2)
- Microsoft.Extensions.Hosting.Abstractions (>= 8.0.1)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.2)
- Silverback.Core (>= 5.0.0-beta.15)
- Silverback.Integration (>= 5.0.0-beta.15)
- Silverback.Integration.Kafka (>= 5.0.0-beta.15)
- System.ComponentModel.Annotations (>= 5.0.0)
- System.Diagnostics.DiagnosticSource (>= 8.0.1)
- System.Linq.Async (>= 6.0.1)
- System.Text.Json (>= 8.0.5)
- System.Threading.Channels (>= 8.0.0)
 
NuGet packages (3)
Showing the top 3 NuGet packages that depend on Silverback.Storage.Relational:
| Package | Downloads | 
|---|---|
| Silverback.Storage.Sqlite Silverback is a powerful, elegant, and feature-rich message bus for .NET, designed to simplify asynchronous messaging, event-driven architectures, and microservice communication. With seamless integration for Apache Kafka and MQTT, it offers robust features for reliability, consistency, and scalability. This package contains Sqlite storage implementation. | |
| Silverback.Storage.PostgreSql Silverback is a powerful, elegant, and feature-rich message bus for .NET, designed to simplify asynchronous messaging, event-driven architectures, and microservice communication. With seamless integration for Apache Kafka and MQTT, it offers robust features for reliability, consistency, and scalability. This package contains the PostgreSql storage implementation. | |
| Silverback.Storage.EntityFramework Silverback is a powerful, elegant, and feature-rich message bus for .NET, designed to simplify asynchronous messaging, event-driven architectures, and microservice communication. With seamless integration for Apache Kafka and MQTT, it offers robust features for reliability, consistency, and scalability. This package contains the Entity Framework (Core) based storage implementation based. | 
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | 
|---|---|---|
| 5.0.0-beta.17 | 58 | 10/20/2025 | 
| 5.0.0-beta.16 | 62 | 10/20/2025 | 
| 5.0.0-beta.15 | 67 | 10/20/2025 | 
| 5.0.0-beta.14 | 122 | 10/6/2025 | 
| 5.0.0-beta.13 | 135 | 9/24/2025 | 
| 5.0.0-beta.12 | 234 | 9/19/2025 | 
| 5.0.0-beta.11 | 121 | 8/20/2025 | 
| 5.0.0-beta.10 | 119 | 8/19/2025 | 
| 5.0.0-beta.9 | 127 | 7/16/2025 | 
| 5.0.0-beta.8 | 130 | 7/16/2025 | 
| 5.0.0-beta.7 | 121 | 7/16/2025 | 
| 5.0.0-beta.6 | 174 | 5/4/2025 | 
| 5.0.0-beta.5 | 143 | 4/27/2025 | 
| 5.0.0-beta.4 | 97 | 4/26/2025 | 
| 5.0.0-beta.3 | 97 | 4/25/2025 | 
| 5.0.0-beta.2 | 163 | 4/21/2025 |