Shuttle.Esb.RabbitMQ 13.2.1

The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org. Prefix Reserved
.NET Standard 2.0
dotnet add package Shuttle.Esb.RabbitMQ --version 13.2.1
NuGet\Install-Package Shuttle.Esb.RabbitMQ -Version 13.2.1
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Shuttle.Esb.RabbitMQ" Version="13.2.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Shuttle.Esb.RabbitMQ --version 13.2.1
#r "nuget: Shuttle.Esb.RabbitMQ, 13.2.1"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. Copy this into the interactive tool or source code of the script to reference the package.
// Install Shuttle.Esb.RabbitMQ as a Cake Addin
#addin nuget:?package=Shuttle.Esb.RabbitMQ&version=13.2.1

// Install Shuttle.Esb.RabbitMQ as a Cake Tool
#tool nuget:?package=Shuttle.Esb.RabbitMQ&version=13.2.1

RabbitMQ

PM> Install-Package Shuttle.Esb.RabbitMQ

This RabbitMQ implementation follows the at-least-once delivery mechanism supported by Shuttle.Esb.

If necessary you may want to use an outbox for a store-and-forward solution. By using a transactional outbox such as the Shuttle.Esb.Sql.Queue implementation you could roll back sending of messages on failure.

Installation

If you need to install RabbitMQ you can <a target='_blank' href='https://www.rabbitmq.com/download.html'>follow these instructions</a>.

Configuration

The URI structure is rabbitmq://configuration-name/queue-name.

services.AddRabbitMQ(builder =>
{
    builder.AddOptions("local", new RabbitMQOptions
    {
        Host = "localhost",
        VirtualHost = "/",
        Port = -1,
        Username = "shuttle",
        Password = "shuttle!",
        PrefetchCount = 25,
        QueueTimeout = TimeSpan.FromMilliseconds(25),
        RequestedHeartbeat = TimeSpan.FromSeconds(30),
        ConnectionCloseTimeout = TimeSpan.FromSeconds(1),
        OperationRetryCount = 3,
        UseBackgroundThreadsForIO = true,
        Priority = 0,
        Persistent = true,
        Durable = true
    });
});

The default JSON settings structure is as follows:

{
  "Shuttle": {
    "RabbitMQ": {
      "local": {
        "Host": "localhost",
        "VirtualHost": "/",
        "Port": -1,
        "Username": "shuttle",
        "Password": "shuttle!",
        "PrefetchCount": 25,
        "QueueTimeout": "00:00:25",
        "RequestedHeartbeat": "00:00:30",
        "ConnectionCloseTimeout": "00:00:01",
        "OperationRetryCount": 3,
        "UseBackgroundThreadsForIO": true,
        "Priority": 0,
        "Persistent": true,
        "Durable": true
      }
    }
  }
}

Options

Option Default Description
Host The RabbitMQ host to connect to.
VirtualHost "/" The virtual host to connect to.
Port -1 Specifies the port to connect to. A value of -1 represents AmqpTcpEndpoint.UseDefaultPort.
Username The username to send as a credential.
Password The password to send as a credential.
PrefetchCount 25 Specifies the number of messages to prefetch from the queue.
QueueTimeout 00:00:25 How long to wait when retrieving a message from the queue before timing out and returing null.
RequestedHeartbeat 00:00:30 Heartbeat timeout to use when negotiating with the server.
ConnectionCloseTimeout 00:00:01 The duration to wait wait for connections to be closed.
OperationRetryCount 3 How many times to retry relevant queue operations in the event that they fail. Once the retries have run out the original exception is thrown.
UseBackgroundThreadsForIO true Determines whether backgrounds threads are used for the I/O loop.
Priority 0 Determines the number of priorities (x-max-priority) supported by the queue.
Persistent true Determines whether messages will be persisted. Please be sure of the possible consequences before setting to 'false'.
Durable true Determines whether the queue is durable. Please be sure of the possible consequences before setting to 'false'.
Product Versions
.NET net5.0 net5.0-windows net6.0 net6.0-android net6.0-ios net6.0-maccatalyst net6.0-macos net6.0-tvos net6.0-windows net7.0 net7.0-android net7.0-ios net7.0-maccatalyst net7.0-macos net7.0-tvos net7.0-windows
.NET Core netcoreapp2.0 netcoreapp2.1 netcoreapp2.2 netcoreapp3.0 netcoreapp3.1
.NET Standard netstandard2.0 netstandard2.1
.NET Framework net461 net462 net463 net47 net471 net472 net48
MonoAndroid monoandroid
MonoMac monomac
MonoTouch monotouch
Tizen tizen40 tizen60
Xamarin.iOS xamarinios
Xamarin.Mac xamarinmac
Xamarin.TVOS xamarintvos
Xamarin.WatchOS xamarinwatchos
Compatible target framework(s)
Additional computed target framework(s)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
13.2.1 63 12/1/2022
13.2.0 170 9/16/2022
13.1.0 176 9/11/2022
13.0.0 177 9/4/2022
12.0.1 340 4/9/2022
12.0.0 231 3/21/2022
11.0.7 1,733 1/20/2021
11.0.6 390 11/27/2020
11.0.5 479 9/7/2020
11.0.4 452 7/19/2020
11.0.3 465 5/21/2020
11.0.2 430 4/28/2020
11.0.1 4,327 8/10/2019
11.0.0 832 6/21/2019
10.0.15 27,323 10/28/2018
10.0.14 737 10/17/2018
10.0.13 747 10/15/2018
10.0.12 730 10/13/2018
10.0.10 763 10/8/2018
10.0.9 722 10/6/2018
10.0.8 754 9/22/2018
10.0.7 820 8/26/2018
10.0.6 963 7/4/2018
10.0.5 965 4/12/2018
10.0.4 1,033 4/8/2018
10.0.3 942 2/13/2018
9.0.1 856 8/6/2017
8.0.2 854 5/15/2017
8.0.1 1,226 4/13/2017
8.0.0 875 3/24/2017
7.0.0 1,305 10/4/2016
6.0.5 1,466 7/23/2016
6.0.4 971 6/21/2016
6.0.3 886 6/20/2016
6.0.2 880 6/4/2016
6.0.1 1,270 4/24/2016
6.0.0 998 4/24/2016
3.9.6 871 4/3/2016
3.9.5 1,064 3/22/2016