Phema.Rabbit.Producers
1.0.2
dotnet add package Phema.Rabbit.Producers --version 1.0.2
NuGet\Install-Package Phema.Rabbit.Producers -Version 1.0.2
<PackageReference Include="Phema.Rabbit.Producers" Version="1.0.2" />
<PackageVersion Include="Phema.Rabbit.Producers" Version="1.0.2" />
<PackageReference Include="Phema.Rabbit.Producers" />
paket add Phema.Rabbit.Producers --version 1.0.2
#r "nuget: Phema.Rabbit.Producers, 1.0.2"
#addin nuget:?package=Phema.Rabbit.Producers&version=1.0.2
#tool nuget:?package=Phema.Rabbit.Producers&version=1.0.2
Phema.Rabbit
public class TestPayload
{
public string Name { get; set; }
}
public class TestModelConsumer : RabbitConsumer<TestPayload>
{
protected override string Tag => "TestModelConsumer";
protected override async Task Consume(TestPayload payload)
{
await Console.Out.WriteLineAsync(payload.Name);
}
}
public class TestPayloadProducer : RabbitProducer<TestPayload>
{
public void Send(TestPayload testPayload)
{
Produce(testPayload);
}
}
public class TestModelQueue : RabbitQueue<TestPayload>
{
protected override string Name => "TestModelQueue";
}
// Startup.cs
services.AddRabbit(options => { /*...*/ })
.AddConsumers(consumers =>
consumers.AddConsumer<TestPayload, TestModelConsumer, TestModelQueue>())
.AddDirectProducers(producers =>
producers.AddProducer<TestPayload, TestPayloadProducer, TestModelQueue>());
Библиотека разделена на три части:
- Базовая с определениями и экстеншеном для конфигурирования
- Консьюмеры и
IHostedService
к ним - Продьюсеры и там же находятся
Exchange
Такой подход нужен в случаях, когда инстанс только обрабатывает очереди или только кладет в них
Чтобы создать:
- Продьюсера нужно отнаследоваться от
RabbitProducer<TPayload>
- Консьюмера -
RabbitConsumer<TPayload>
- Очередь -
RabbitQueue<TPayload>
- Об
Exchange
пунктом ниже. И по неоходимости переопределить нужные параметры
- Продьюсера нужно отнаследоваться от
Существует 4 предопределенных Exchange -
DirectRabbitExchange
,FanoutRabbitExchange
,HeadersRabbitExchange
, `TopicRabbitExchangeКаждый инстанс создает одно соединение с реббитом как для консьюмеров, так и для продьюсеров
Количество консьюмеров на инстансе определяется свойством Parallelism. Все консьюмеры будут находиться в одном канале с тегами
Название_Порядковый номер
Все продьюсеры -
Scoped-сервисы
и создают новый канал (не соединение!) на время отправки, что позволяет добавлять в очередь сообщения вне зависимости от количества запросов и обеспечивать потокобезопасностьДля консьюмеров используется
IHostedService
, после завершения заботы AspNetCore хоста, они не смогут больше обрабатывать сообщения, даже если приложение продолжит свою работуЧтобы задать название инстанса в реббите определите
options.InstanceName
Если хотите работать с реббитом напрямую - в DI добавлен
IConnection
текущего инстансаВсе консьюмеры используют наследника
AsyncEventingBasicConsumer
для обработки сообщенийМожно не добавлять
RabbitOptions
черезAddRabbit(options => ...)
, если используются сторонние механизмы конфигурацииЧерез
RabbitOptions
можно определить кодировку, по-умолчанию -utf-8
Для сериализации используется
Newtonsoft.Json
без возможности замены. Для конфигурации настроек сериализации естьRabbitOptions.SerializerSettings
RabbitConsumer
-Scoped
-сервис. Использует одну модель для обработки. Создается на каждое новое сообщение. Это нужно для обновления всехScoped
сервисов в зависимостях консьюмераВ качестве
RoutingKey
в очереди по-умолчанию используется ее имя.Если у
RabbitProducer
не указанRoutingKey
используется ключ изRabbitQueue
Для асинхронного добавления в очередь используется
ProduceAsync
уRabbitProducer
По-умолчанию
Prefetch
уRabbitConsumer
равен нулюПо-умолчанию
Mandatory
уRabbitProducer
задан вfalse
. Реббит будет выкидывать такие сообщения, если не найдет подходящую очередь (Зависит от типаRabbitExchange
,RoutingKey
уRabbitQueue
иRoutingKey
уRabbitProducer
)
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. 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. |
.NET Core | netcoreapp2.2 is compatible. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
-
.NETCoreApp 2.2
- Phema.Rabbit (>= 1.0.2)
- Phema.Serialization (>= 1.0.0)
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 |
---|