- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在处理一种情况,我从现场的设备接收消息。这些消息已经被标记了序列号,我需要按照原来的顺序处理这些消息。消息丢失的情况很少见,但并非不可能,因此我需要一种机制来处理它。
我的实现是基于 NServiceBus 构建的,并且我正在使用“HandleCurrentMessageLater”功能在消息被乱序接收的情况下将消息弹出到队列的后面。
只要我最终收到序列中的下一条消息,这样我就可以处理积压的工作,这种方法就可以很好地工作。
在这种情况下,我有哪些选项可以处理丢失的消息?我的第一 react 是实现某种老化算法,在一定次数的失败尝试或类似操作后增加序列号,但是必须这样做的复杂性有点过分。
有没有人遇到过类似的问题并愿意分享他们是如何解决的?
谢谢
最佳答案
在我看来,这是您需要业务部门提供的信息。是否有时间限制,在该时间限制之后可以假定该消息不可撤销地丢失?如果是这样,在这种情况下应该采取哪些商业行动?如果最终收到该消息但在超时之后会发生什么情况?
您可以使用 Saga 实现这些案例。如果消息到达但顺序不对,那么您仍然会调用 HandleCurrentMessageLater,但您也会请求超时,以便如果在业务批准的超时后这些条件仍然为真,则补偿操作可以运行,其余的可以处理备份的消息。
或者,可能有替代解决方案。您说您需要按原始顺序处理消息。您没有详细说明这对现实生活的影响,但这听起来像是高级业务需求,而不是技术需求。换句话说,这就是企业希望看到的方式,但不一定是实际发生的方式。也许您可以正常处理有序消息,并增加一个值,该值指示收集的数据对哪个序列号有效。如果消息乱序到达,它们仍然可以被软处理,但序列号不会增加。
所以基本上你会收到消息 1-5 并正常处理它们。然后你收到 7-10(6 已被跳过)并处理它们,但 ValidSequenceNumber 仍然是 5。然后当 #6 到达时,你处理它,采取任何补偿措施来 catch ,ValidSequenceNumber 现在是 10。 Saga 也是实现这种逻辑的一个很好的候选者。
关于architecture - 顺序很重要时丢失消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14137946/
如果您设计分布式应用程序以实现轻松扩展,或者您只想使用 Amazon、Google 或 Microsoft 提供的任何新的“云计算”产品,那么您通常最终会使用一些典型的概念或组件: 分布式 blob
根据uncle Bob's Clean Architecture 、企业和应用程序业务规则(概念上由命令组成)位于外部接口(interface)层之下的层中。因此,无论何时调用接口(interface
我在网上找不到它的任何实现实际上为您提供了一种与框架无关且实用的实现方式。 我已经看到了几个解决它的低于标准的建议: 使存储库方法成为原子 使用例原子化 它们都不是理想的。 案例#1 :大多数用例依赖
我正在查看 Sparkle 项目的配置并注意到它们设置: 架构 = ppc i386 x86_64 有效架构 = i386 x86_64 来自苹果的有效架构描述: Space-separated li
只听本周的podcast并认为将您的一些经验组合在一起会很好,在这些经验中,您已经看到设计的“架构”方面比应有的支配更多东西。 Java 在这方面经常受到负面报道,而且随着 Java EE 的复杂性增
我正在阅读 Bob Martin (https://blog.8thlight.com/uncle-bob/2012/08/13/the-clean-architecture.html) 的清洁架构
OSGi是模块化架构,JavaBeans是组件架构。有什么区别? 最佳答案 OSGi 和 Java Beans 之间的主要区别在于类加载器的工作方式。在标准 .jar 文件或 EJB 中,rt.jar
我对 Clean Architecture 中的 Gateway to Entity 依赖有疑问。我认为以下同心圆图形经常被介绍为整洁的架构。 在上图中,Gateway并没有直视Entity。但是,还
我试图理解 TOGAF 9 的核心概念。 无论我多长时间阅读 TOGAF 手册中的解释,我都无法理解 Enterprise Continuum 和 Architecture Repository 之间
如果 Kappa 架构直接对流进行分析,而不是将数据拆分为两个流,那么在像 Kafka 这样的消息系统中,数据存储在哪里?或者它可以在数据库中进行重新计算? 单独的批处理层是否比使用流处理引擎重新计算
它们的含义是什么,我可以将它们设置为不同的值吗? 最佳答案 架构是您想要构建的架构,有效的架构是您可以设想使用您的代码库构建的架构。 所以也许您只想为 armv7 构建二进制文件,但相同的源代码可以为
我现在正在尝试在 Xcode 4.0 中构建的项目遇到问题,希望有人可以为我解释一下。 我正在尝试使用 ZBar SDK 并遵循此处概述的指南中概述的说明: http://zbar.sourcefor
在基于 Apple Silicon 的机器上使用 Interface builder 时,我当前的项目会引发 IBDesignable 错误。 我尝试排除用于调试的 arm64 架构,以及我在互联网上
Xcode 项目中出现警告: crypto was rejected as an implicit dependency for 'libcrypto.a' because its architect
我正在 Xcode 5 中开始新项目。我想使用 iOS SDK 7 开发应用程序,但部署目标为 iOS 5.0。当我在 Xcode 中创建新项目并尝试将部署目标更改为 5.0 时,我收到了这条消息:
编辑 :这个问题可能是旧的,它与 xcode 3 有关。 我正在开发一个需要 voip 支持的 iPhone 应用程序,所以我添加了 pjsip 的 ARM 版本图书馆。但如果我使用 iPhone 模
我们最近将最低 iOS 支持设置为 4.0,并开始使用 LLVM 编译器对当前可用的应用程序进行新更新。 将“架构”和“有效架构”设置为仅 armv7 是否会排除 iPhone 3G 等 armv6
我想在我的 64 位机器上启用额外的架构(32 位)。我做了 dpkg --print-architecture 来了解已知的架构,即 amd64 。之后我做了 dpkg --print--forei
操作系统:OS X Yosemite 版本 10.10.1 XCode:未安装 应用程序加载器3.0 (620) PhoneGap:3.7.0 PhoneGap 构建:在线 (build.phoneg
我们已经构建了一个具有多个 native 绑定(bind)的 Xamarin 应用程序(iOS、Android)。该应用程序在设备和模拟器上运行良好,我们能够毫无问题地构建存档(显然)。 问题是当我们
我是一名优秀的程序员,十分优秀!