- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我已经阅读了 What design decisions would favour Scala's Actors instead of JMS? 的问题和答案.
通常,我们使用已经存在多年的消息传递解决方案:要么使用 JMS 实现(如 WebSphere MQ 或 Apache ActiveMQ)进行点对点通信,要么使用 Tibco Rendevous 进行多播消息传递。
它们非常稳定,经过验证并提供高可用性和性能。然而,配置和设置似乎比 Akka 复杂得多。
对于迄今为止已成功使用上述产品(WebSphere MQ 或 ActiveMQ)的某些用例,何时以及为何应使用 Akka?为什么我应该在 future 的项目中考虑使用 Akka 而不是 WebSphere MQ 或 Tibco RV?
我什么时候应该避免使用 Akka?它是否提供与其他解决方案相同的高可用性和性能?或者甚至将 Akka 与其他消息传递中间件进行比较是一个坏主意?
也许除了 JMS(点对点)、TibcoRV(多播)和 Akka 之外,我还应该考虑 JVM 环境中的另一种消息传递解决方案?
最佳答案
首先,“较旧的”消息系统 (MQ) 在实现上较旧,但它们在工程理念上较新:事务持久队列。 Scala Actors 和 Akka 可能是较新的实现,但构建在较旧的 Actors 并发模型之上。
然而,这两个模型在实践中非常相似,因为它们都是基于事件消息的:请参阅我对 RabbitMQ vs Akka 的回答。 .
如果您只想为 JVM 编写代码,那么 Akka 可能是一个不错的选择。否则我会使用RabbitMQ。
此外,如果您是 Scala 开发人员,那么 Akka 应该是显而易见的。然而,Akka 的 Java 绑定(bind)不是很像 Java 风格,并且由于 Scala 的类型系统需要进行转换。
同样在 Java 中,人们通常不会创建不可变对象(immutable对象),我建议您为消息传递这样做。因此,在 Java 中很容易意外地使用 Akka 做一些不会扩展的事情(使用可变对象作为消息,依赖于奇怪的闭包回调状态)。使用 MQ 这不是问题,因为消息总是以速度为代价进行序列化。对于 Akka,它们通常不是。
与大多数 MQ 相比,Akka 在拥有大量消费者的情况下也能更好地扩展。这是因为对于大多数 MQ(JMS、AMQP)客户端来说,每个队列连接都需要一个线程……因此很多队列 == 很多永久运行的线程。不过,这主要是客户端问题。我认为 ActiveMQ Apollo 有一个非阻塞调度程序,据称可以为 AMQP 解决这个问题。 RabbitMQ 客户端具有允许您组合多个消费者的 channel ,但仍然存在大量消费者可能导致死锁或连接死亡的问题,因此通常会添加更多线程来避免此问题。
话虽如此 Akka's remoting是相当新的,可能仍然没有提供传统消息队列提供的所有可靠消息保证和 QoS(但每天都在变化)。它通常也是点对点的,但我认为它是否支持服务器对点,这通常是大多数 MQ 系统所做的(即单点故障),但有些 MQ 系统是点对点的(RabbitMQ 是服务器-对等)。
最后 RabbitMQ 和 Akka 实际上是一对很好的搭档。 您可以使用 Akka 作为 RabbitMQ 的包装器,特别是因为 RabbitMQ 不能帮助您处理消息的消耗和本地路由消息(在单个 JVM 中)。
何时选择 Akka
关于java - 何时使用参与者而不是消息传递解决方案,例如 WebSphere MQ 或 Tibco Rendezvous?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5693346/
我们目前使用 MQ Explorer 来管理 Z/OS 上的 WebSphere MQ V7。前几天误删了一个队列。后来我想回顾一下历史并查看一些日志以了解它究竟发生在何时。我的问题是,MQ Expl
默认情况下是否安装了扩展事务客户端?如何验证是否已安装?我如何安装这个? 最佳答案 在先前版本的 MQ 客户端中,它当然不包含在标准客户端中(事务客户端具有成本/许可影响)。 但是,从 WMQ v7.
我有 2 个队列,比如 Q1 和 Q2。当我使用 MQPUT 将消息插入 Q1 时,有什么方法可以将此消息复制到 Q2 中吗? WMQ 是否支持队列复制? 注意:队列驻留在不同的队列管理器上。 谢谢,
我有一个进程,它使用 JMSTemplate 根据 JMS header 值有选择地从 MQ 队列中出列。 当出队查询匹配队列前面的消息时,出队速率约为 60-70 条消息/秒。但是,当查询仅匹配 5
Source LogPrimaryFiles=3|2-254 (Windows)|2-510 (UNIX systems) The log files allocated when the queue
在Websphere MQ系列中,队列管理器的命令级别是701。它实际上指定了什么? 最佳答案 WebSphere 产品使用“[版本].[发行版].[修改].[修订包]”命名约定。例如,7.0.1.6
在哪里可以找到 IBM MQ 版本 V8.0.0.5 和 V9.0 之间的区别?我试图在 IBM 网站上查找它,但没有成功。 最佳答案 IBM 的 v9 知识中心页面“What's new in Ve
我已经在我的机器上安装了 MQ(已经用 regedit32 检查过)但是当我在命令提示符下键入“runmqsc”时出现错误“无法识别命令”(为 mqjms.jar 设置了环境变量)我是什么失踪 ?我想
我在我的系统中安装了 MQ V8.0.0.2,我正在应用修复包以使用静默安装方法将其升级到 8.0.0.5。它运行成功并完成,但 dspmqver仍然说版本为 8.0.0.2。 它在 64 位的 Wi
我们有一个场景,我们希望 node.js 应用程序使用来自后端系统的消息,该后端系统当前将消息放入 Websphere MQ 队列(通过 SAP PI)。 在 MQ 8.0.0.3 中,有一个 AMQ
我们有消息通过 WebSphere MQ 队列传入。我们需要很长时间才能收到消息。 是否有一种简单易行的方法来跟踪收到/提取消息的时间? 最佳答案 发送消息后,您可以请求确认交货。当消息被消费时,一条
我想将文件系统中的文件加载到 WebSphere MQ 队列。有几个支持 pacs - Q Program和 MO03: WebSphere MQ Queue Load / Unload Utilit
有人使用过 RPG 中的 MQ 吗?问题如下。队列中有几条消息。它们都带有 RFH2 header 。每个 header 都包含一组 NameValueData。我正在创建消息句柄并将其传递给 MQG
我有一组 IBM MQ 队列管理器,想知道其中一个何时重新启动或何时自动故障转移到备用实例。 队列管理器位于 AIX 上 问候, 最佳答案 您可以从 AMQERR01.LOG 中找到此信息。队列管理器
作为我们应用程序安装的一部分,我需要将一堆 xml 消息放入一个 MQ 队列中。为了使它更复杂,消息需要设置 RFH2 header 的 usr 文件夹。 我发现 mqput2.exe来自 IBM R
我一直在研究变幻莫测的 channel 状态、它们如何进入这些状态以及如何停止或启动它们。我现在已经有了相当扎实的理解,但是一位同事提出了 channel 重置的话题。 当我无法解释发生了什么时,我偶
我从 MQ 安全演示文稿中看到一项建议,如果您不需要命令服务器,它会关闭它。我的问题是如何确定我是否真的需要它。 从我的角度来看,如果没有运行目标 QMGR 的管理程序,例如 MQ Explorer
是否可以保留已检索且不再位于队列中的消息历史记录(包含消息内容将是完美的)? 在应用程序中,我可以看到发送者何时尝试将消息放入队列以及接收者何时尝试拾取消息,但我想查看消息何时真正到达队列以及消息何时
有没有办法找到在特定时间段内通过 IBM websphere MQ 队列管理器的消息总数? 最佳答案 这听起来像是 MQ 记帐和统计功能的完美使用。除此之外,这些功能还记录消息数量(具有持久和非持久计
我正在向远程队列发送消息,但我无法控制该队列。 我发送一个 xml 文件作为消息,但是当应用程序读取消息时,它会得到一个消息头,例如 jms_text \0\0\0lqueue:///TEST128
我是一名优秀的程序员,十分优秀!