- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
当发生错误消息发布到默认 EasyNetQ_Default_Error_Queue 时,我有四个消费者是否可以让每个队列消费者编写自己的错误交换
例如;
Queue Name : A ErrorExchange :A_ErrorExchange
Queue Name : B ErrorExchange :B_ErrorExchange
bus.Advanced.Conventions.ErrorExchangeNamingConvention = new ErrorExchangeNameConvention(info => "A_DeadLetter");
bus.Advanced.Conventions.ErrorExchangeNamingConvention = new ErrorExchangeNameConvention(info2 => "B_DeadLetter");
最佳答案
从您提供的代码来看,您似乎快完成了——您只需要适本地覆盖 ErrorExchangeNamingConvention
和 ErrorQueueNamingConvention
。
例如,这里有一个方法将返回 IBus
的实例,并覆盖这些约定以合并指定的消费者名称:
public IBus CreateBus(string connectionString, string consumerName)
{
var bus = RabbitHutch.CreateBus(connectionString);
// Modify the following to create your error exchange name appropriately
bus.Advanced.Container.Resolve<IConventions>().ErrorExchangeNamingConvention =
info => consumerName + "_ErrorExchange";
// Modify the following to create your error queue name appropriately
bus.Advanced.Container.Resolve<IConventions>().ErrorQueueNamingConvention =
() => consumerName + "_ErrorQueue";
return bus;
}
关于c# - 如何在 EasyNetQ 中为每个消费者声明自定义错误交换?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30547475/
我使用 EasyNetQ 为 RabbitMQ 实现了一个简单的客户端。连接后,我收到通知“队列模型关闭”。这是我的代码: var _bus = RabbitHutch.CreateBus(Strin
我使用 EasyNetQ 为 RabbitMQ 实现了一个简单的客户端。连接后,我收到通知“队列模型关闭”。这是我的代码: var _bus = RabbitHutch.CreateBus(Strin
我正在考虑使用 EasyNetQ 与 RabbitMQ 进行交互,想知道它是否可以支持以下情况: 使用一些任意参数(例如 x-message-ttl)在外部声明队列 使用 EasyNetQ 的客户端代
在我的测试应用程序中,我可以看到处理异常的消息被自动插入到默认的 EasyNetQ_Default_Error_Queue 中,这很棒。然后我可以使用 Hosepipe 成功地转储或重新排队这些消息。
我正在使用EasyNetQ,需要重试原始队列中的失败消息。问题是:即使我成功地增加了TriedCount变量(在每个msg的正文中),当EasyNetQ在异常发生后将消息发布到默认错误队列时,更新的T
我目前正在调查此问题,但我还是想问问。如果没有回答,我会在发现后发布答案。 问题如下: 应用程序调用 RabbitHutch.CreateBus 来创建 IBus/IAdvancedBus 的实例,以
我们使用 RabbitMQ 在 C# .Net(EasyNetQ 客户端)中对消息进行排队。 我想要一个消费者应用程序(C# 控制台应用程序)监听一个队列并为每种消息类型提供多个处理程序。 我实现了这
当发生错误消息发布到默认 EasyNetQ_Default_Error_Queue 时,我有四个消费者是否可以让每个队列消费者编写自己的错误交换 例如; Queue Name : A Error
我正在我的软件中尝试一些边缘情况。所以我创建了一个非常简单的测试环境: 在 CentOS 7 上运行的 RabbitMQ 服务器 在 CentOS 7 下运行的 C# 中针对 .NETCore 2.1
我最近发布了以下问题... Custom Error Queue Name when using EasyNetQ for RabbitMQ? ... 并提供了有关如何在使用 EasyNetQ 时使用
我在 C# 中使用 RabbitMQ 和 EasyNetQ 库。我在这里使用发布/订阅模式。我还有一些问题希望有人能帮助我解决: 如果在使用消息时出现错误,它会自动移至错误队列。我如何实现重试(以便它
当发布者希望消息得到答复时,如何确保在您将其扩展时它只会获得(对自己的消息)相关的答复? 我们有一个客户端进程发布一条消息供服务器进程回答。此外,我们有一个“监听器”进程,它只需要在不发布任何内容的情
我正在使用 EasyNetQ,我想知道如何获取现有的 IExchange和 IQueue不提前订阅? 在 IAdvanceBus我只能看到: ExchangeDeclareAsync QueueDec
我是消息传递新手,目前正在使用 RabbitMQ 进行调查作为我们系统架构的一部分,在不同服务之间提供消息传递。我有一个basic RabbitMQ example工作并且它可以通过总线传输基本的文本
我正在尝试使用 EasyNetQ 连接到 RabbitMQ。RabbitMQ 位于远程虚拟机上。 _rabbitBus = RabbitHutch.CreateBus( string.Form
所以我有以下架构:Angular SPA(单页应用程序)执行对 .NET Web API Controller 的调用,后者将消息发布到 Publisher EasyNetQ 窗口服务,后者将异步请求
谁能指导我找到适用于 Unity 5.x (.Net 3.5) 项目的 EasyNetQ 的正确版本? 我有一个针对 .Net framework 3.5(Unity 3.5 .net 子集基类库)的
与其让我未处理的异常进入EasyNetQ_Default_Error_Queue,我想知道是否有一种方法可以明确说明应该用于给定应用程序的错误队列的名称,因此错误不会t ALL 最终都在这个 Easy
我正在尝试将 EasyNetQ 与 Ninject 结合使用来记录消息。 我已经设法将 Ninject 设置为 EasyNetQ DI(我认为),但是当消息到达没有无参数构造函数的处理程序时(例如,我
我可以使用以下代码成功发布消息: using (IAdvancedBus bus = RabbitHutch.CreateBus("host=192.168.153.128:5672;
我是一名优秀的程序员,十分优秀!