- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我在 C# 中使用 RabbitMQ 和 EasyNetQ 库。我在这里使用发布/订阅模式。我还有一些问题希望有人能帮助我解决:
有人吗?
最佳答案
您在使用 EasyNetQ/RabbitMQ 时遇到的问题是,与 SQS 或 Azure 服务总线/队列等其他消息服务相比,它更加“原始”,但我会尽力为您指明正确的方向.
问题 1.
这将由您来完成。最简单的方法是在 RabbitMQ/EasyNetQ 中 No-Ack 一个消息,它会被放在队列的头部让你重试。这并不是真正可取的,因为它几乎会立即重试(没有时间延迟),并且还会阻止处理其他消息(如果您有一个预取计数为 1 的订阅者)。
我见过使用“MessageEnvelope”的其他实现。因此,一个包装类,当消息失败时,您可以在 MessageEnvelope 上增加一个重试变量,并将消息重新传递回队列。您将不得不这样做并围绕您的消息处理程序编写包装代码,这不是 EasyNetQ 的功能。
使用上面的方法,我也看到人们使用信封,但允许消息是死信。一旦它在死信队列中,就会有另一个应用程序/工作人员从死信队列中读取项目。
上述所有这些方法都有一个小问题,即在处理消息时并没有任何好的方法来实现对数/指数/任何类型的增加延迟。在将消息返回到队列之前,您可以在代码中“保留”该消息一段时间,但这不是一个好的解决方法。
在所有这些选项中,您自己的自定义应用程序读取死信队列并根据包含重试计数的信封决定是否重新路由消息可能是最好的方法。
问题 2.
您可以使用高级 API 为每个队列指定死信交换。 (https://github.com/EasyNetQ/EasyNetQ/wiki/The-Advanced-API#declaring-queues)。然而,这意味着您将不得不在几乎所有地方使用高级 API,因为使用订阅/发布的简单 IBus 实现会查找基于消息类型和订阅者名称命名的队列。使用自定义队列声明意味着您将自己处理队列的命名,这意味着当您订阅时,您将需要知道您想要的名称等。不再为您自动订阅!
问题 3
错误队列/死信队列只是另一个队列。您可以收听此队列并使用它执行您需要执行的操作。但是实际上并没有任何开箱即用的解决方案听起来可以满足您的需求。
关于c# - 如何使用 EasyNetQ/RabbitMQ 进行错误处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30914640/
我使用 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;
我是一名优秀的程序员,十分优秀!