Shuttle.Esb
20.0.0
Prefix Reserved
dotnet add package Shuttle.Esb --version 20.0.0
NuGet\Install-Package Shuttle.Esb -Version 20.0.0
<PackageReference Include="Shuttle.Esb" Version="20.0.0" />
<PackageVersion Include="Shuttle.Esb" Version="20.0.0" />
<PackageReference Include="Shuttle.Esb" />
paket add Shuttle.Esb --version 20.0.0
#r "nuget: Shuttle.Esb, 20.0.0"
#:package Shuttle.Esb@20.0.0
#addin nuget:?package=Shuttle.Esb&version=20.0.0
#tool nuget:?package=Shuttle.Esb&version=20.0.0
Documentation
Please visit out official documentation for more information.
Getting Started
Start a new Console Application project. We'll need to install one of the support queue implementations. For this example we'll use Shuttle.Esb.AzureStorageQueues which can be hosted locally using Azurite:
PM> Install-Package Shuttle.Esb.AzureStorageQueues
We'll also make use of the .NET generic host:
PM> Install-Package Microsoft.Extensions.Hosting
Next we'll implement our endpoint in order to start listening on our queue:
internal class Program
{
static async Task Main(string[] args)
{
await Host.CreateDefaultBuilder()
.ConfigureServices(services =>
{
services
.AddServiceBus(builder =>
{
builder.Options.Inbox.WorkQueueUri = "azuresq://azure/work";
// Delegates may also be added to the builder, including adding dependencies
builder.AddMessageHandler(async (IHandlerContext<SomeMessage> context, ISomeDependency instance) =>
{
Console.WriteLine($@"[some-message] : guid = {context.Message.Guid}");
await Task.CompletedTask;
});
})
.AddAzureStorageQueues(builder =>
{
builder.AddOptions("azure", new AzureStorageQueueOptions
{
ConnectionString = "UseDevelopmentStorage=true;"
});
});
})
.Build()
.RunAsync();
}
}
Even though the options may be set directly as above, typically one would make use of a configuration provider:
internal class Program
{
private static async Task Main(string[] args)
{
await Host.CreateDefaultBuilder()
.ConfigureServices(services =>
{
var configuration =
new ConfigurationBuilder()
.AddJsonFile("appsettings.json")
.Build();
services
.AddSingleton<IConfiguration>(configuration)
.AddServiceBus(builder =>
{
configuration
.GetSection(ServiceBusOptions.SectionName)
.Bind(builder.Options);
})
.AddAzureStorageQueues(builder =>
{
builder.AddOptions("azure", new AzureStorageQueueOptions
{
ConnectionString = configuration
.GetConnectionString("azure")
});
});
})
.Build()
.RunAsync();
}
}
The appsettings.json file would be as follows (remember to set to Copy always):
{
"ConnectionStrings": {
"azure": "UseDevelopmentStorage=true;"
},
"Shuttle": {
"ServiceBus": {
"Inbox": {
"WorkQueueUri": "azuresq://azure/work",
}
}
}
}
Send a command message for processing
await serviceBus.SendAsync(new RegisterMember
{
UserName = "user-name",
EMailAddress = "user@domain.com"
});
Publish an event message when something interesting happens
Before publishing an event one would need to register an ISubscrtiptionService implementation such as Shuttle.Esb.Sql.Subscription.
await serviceBus.PublishAsync(new MemberRegistered
{
UserName = "user-name"
});
Subscribe to those interesting events
services.AddServiceBus(builder =>
{
builder.AddSubscription<MemberRegistered>();
});
Handle any messages
public class RegisterMemberHandler : IMessageHandler<RegisterMember>
{
public RegisterMemberHandler(IDependency dependency)
{
}
public async Task ProcessMessageAsync(IHandlerContext<RegisterMember> context)
{
// perform member registration
await context.PublishAsync(new MemberRegistered
{
UserName = context.Message.UserName
});
}
}
public class MemberRegisteredHandler : IMessageHandler<MemberRegistered>
{
public async Task ProcessMessageAsync(IHandlerContext<MemberRegistered> context)
{
// processing
}
}
| 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. |
-
- Microsoft.Extensions.DependencyInjection (>= 8.0.1)
- Microsoft.Extensions.Hosting (>= 8.0.1)
- Shuttle.Core.Compression (>= 20.0.0)
- Shuttle.Core.Contract (>= 20.0.0)
- Shuttle.Core.Encryption (>= 20.0.0)
- Shuttle.Core.Pipelines (>= 20.0.0)
- Shuttle.Core.PipelineTransactionScope (>= 20.0.0)
- Shuttle.Core.Reflection (>= 20.0.0)
- Shuttle.Core.Serialization (>= 20.0.0)
- Shuttle.Core.Specification (>= 20.0.0)
- Shuttle.Core.Streams (>= 20.0.0)
- Shuttle.Core.System (>= 20.0.0)
- Shuttle.Core.Threading (>= 20.0.0)
- Shuttle.Core.TransactionScope (>= 20.0.0)
NuGet packages (30)
Showing the top 5 NuGet packages that depend on Shuttle.Esb:
| Package | Downloads |
|---|---|
|
Shuttle.Esb.RabbitMQ
RabbitMQ implementation for use with Shuttle.Esb. |
|
|
Shuttle.Esb.Tests
Test fixtures to facilitate testing of components, such as queues, that relate to Shuttle.Esb. |
|
|
Shuttle.Esb.Process
Shuttle.Esb process management using Shuttle.Recall event sourcing. |
|
|
Shuttle.Esb.Sql.Subscription
Sql-based implementation of ISubscriptionService interface for use with Shuttle.Esb implementations. |
|
|
Shuttle.Esb.FileMQ
File-based queue implementation for use with Shuttle.Esb. |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 20.0.0 | 2,989 | 2/2/2025 |
| 15.0.0 | 2,019 | 8/5/2024 |
| 14.0.1 | 2,755 | 5/3/2024 |
| 14.0.0 | 1,154 | 4/30/2024 |
| 13.2.1 | 13,641 | 12/1/2022 |
| 13.2.0 | 10,162 | 9/16/2022 |
| 13.1.0 | 8,598 | 9/11/2022 |
| 13.0.0 | 8,548 | 9/4/2022 |
| 12.1.1 | 1,726 | 5/18/2022 |
| 12.1.0 | 1,531 | 5/18/2022 |
| 12.0.1 | 9,911 | 4/9/2022 |
| 12.0.0 | 9,008 | 3/21/2022 |
| 11.2.0 | 8,724 | 2/15/2021 |
| 11.1.1 | 1,742 | 2/9/2021 |
| 11.1.0 | 1,957 | 1/30/2021 |
| 11.0.3 | 13,456 | 1/17/2021 |
| 11.0.2 | 2,466 | 11/27/2020 |
| 11.0.1 | 23,928 | 7/31/2019 |
| 11.0.0 | 14,008 | 6/20/2019 |
| 10.1.8 | 3,142 | 12/26/2018 |