- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发使用传输层和点对点 MQ 通信的现有应用程序。
对于每个给定的帐户列表,我们需要检索一些信息。
目前我们有这样的东西来与 MQ 通信:
responseObject getInfo(requestObject){
code to send message to MQ
code to retrieve message from MQ
}
如您所见,我们等到它完全完成后再继续下一个帐户。由于性能问题,我们需要对其进行返工。
目前我可以想到 2 种可能的情况。
1) 在应用程序中创建一组线程,为每个帐户执行传输适配器。然后从每个任务中获取数据。我更喜欢这种方法,但一些团队成员认为传输层是进行此类更改的更好位置,我们应该将额外的负载放在 MQ 而不是我们的应用程序上。
2) 重做传输层以使用发布/订阅模型。理想情况下,我想要这样的东西:
void send (requestObject){
code to send message to MQ
}
responseObject receive()
{
code to retrieve message from MQ
}
然后我将只在循环中发送请求,然后在循环中检索数据。这个想法是,当后端系统正在处理第一个请求时,我们不必等待响应,而是发送下一个请求。
我的问题是,它会比当前的顺序检索快很多吗?
最佳答案
问题标题将此定义为 P2P 和发布/订阅之间的选择,但问题正文将其定义为线程处理和流水线处理之间的选择。这是两个完全不同的东西。
提供的任一代码片段都可以轻松地使用 P2P 或发布/订阅来放置和获取消息。该决定不应基于速度,而应基于所讨论的接口(interface)是否需要将单个消息传递给多个接收者。如果答案是否定的,那么您可能希望坚持使用点对点,而不管您的应用程序的线程模型如何。
顺便说一下,标题中提出的问题的答案是“否”。当您使用点对点模型时,您的消息会立即解析到目的地或传输队列,WebSphere MQ 从那里路由它们。通过发布/订阅,您的消息被传递到一个内部代理进程,该进程将零解析为许多可能的目的地。只有在这一步之后,发布的消息才会被放入队列中,在接下来的旅程中,它会像任何其他点对点消息一样被处理。尽管发布/订阅通常不会明显慢于点对点,但代码路径更长,因此,在所有其他条件相同的情况下,它会增加一点延迟。
问题的另一部分是关于并行性的。您建议要么启动多个线程,要么拆分应用程序,以便分别处理请求和回复。第三种选择是运行多个应用程序实例。您可以在您的设计中组合任何或所有这些。例如,您可以启动多个请求线程和多个回复线程,然后让应用程序实例针对多个队列管理器进行处理。
这个问题的关键是消息之间是否具有亲和性、排序依赖性或创建它们的应用程序实例或线程。例如,如果我使用请求/回复响应 HTTP 请求,那么附加到 HTTP session 的线程可能需要是接收回复的线程。但是,如果回复确实是异步的,而我需要做的就是用响应数据更新数据库,那么拥有单独的请求和回复线程会很有帮助。
无论哪种情况,动态增加或减少实例数量的能力都有助于管理峰值工作负载。如果这是单独使用线程来完成的,那么您的性能可伸缩性将受到单个服务器的上限。如果这是通过在相同或不同的服务器/QMgr 上启动新的应用程序实例来实现的,那么您将同时获得可扩展性和工作负载平衡。
有关这些主题的更多想法,请参阅以下文章:Mission:Messaging: Migration, failover, and scaling in a WebSphere MQ cluster
此外,转到 WebSphere MQ SupportPacs页面并查找适用于您的平台和 WMQ 版本的 Performance SupportPac。这些是以 MP** 开头的名称。这些将向您展示随着连接的应用程序实例数量的变化而变化的性能特征。
关于java - MQ 发布/订阅域特定接口(interface)通常比点对点更快吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6034670/
时间过后如何用javascript或任何其他解释语言实现的函数被调用? 换句话说,在javascript解释器中是否存在循环,该循环始终检查计时器列表,或者操作系统是否有任何特定方式来处理此循环? 谢
我有项目要做。假设是这样的: 从带有单词的文件中,我只需要阅读字母单词(进入名为Words的列表-下面的代码)-我是使用lib中的isalpha()函数做到的。列表的每个元素包含一个单词 我需要从输入
我有两套test和 test1我需要从 test 中删除元素存在于 test1例如 如果test包含 1,2,3,4,5 和 test1包含 3,5,6,7:那么函数应该在 test 上执行所以里面只
引用指针导致间接使用对象的值。但我从来没有真正理解“使用”是什么意思。我开始思考这个问题,直到我的编译器对以下代码产生错误 int i = 0, *pi = &i; decltype(*pi) c;
我读了很多关于 Taint在 Perl 变量、模式等中,例如来自 docs : $AUTOLOAD can now be tainted If you call a subroutine by a t
我一直在研究 FP 语言(断断续续),并且使用过 Scala、Haskell、F# 和其他一些语言。我喜欢我所看到的并理解 FP 的一些基本概念(绝对没有范畴论的背景——所以请不要谈论数学)。 所以,
在C语言中,当您想要进行通用编程时,唯一受语言支持的选项是宏。它们效果很好并且被广泛使用,但是如果可以使用内联函数或常规函数,则不建议使用它们。 (如果使用gcc,您还可以使用gcc statemen
我有一些代码可以进行 requests.get() 调用,这可能会以各种方式失败。我想捕获 requests 异常,但不关心调用失败的原因。 我想避免这样的代码 try: r = reques
我正在尝试编写一个 C 解析器,用于我自己的教育。我知道我可以使用像 YACC 这样的工具来简化这个过程,但我想尽可能多地从经验中学习,所以我从头开始。 我的问题是我应该如何处理这样的一行: doSo
我正在设计一个系统,但我认为让最终用户能够删除数据库中的条目并不是一个好主意。我是这么认为的,因为通常最终用户一旦获得管理员权限,最终可能会在数据库中弄得一团糟,然后求助于我来修复它。 当然,如果他们
我们有两张 table 。第一个包含名称 (varchar) 字段。第二个包含引用第一个表中的名称字段的字段。第二个表中的外键将针对与该名称关联的每一行重复。通常不鼓励使用 varchar/strin
我正在为 Apple Watch 开发一个非常简单的锻炼应用程序。它使用 Health Kit 开始和结束锻炼,我唯一的问题是,当我尝试结束锻炼时,它通常不会结束 session ,我收到此错误 20
当前,我们在执行sql查询脚本时遇到一些失败的问题。 错误讯息为, ” 系统断言检查失败。检查SQL Server错误日志以获取详细信息。通常,断言失败是由软件错误或数据损坏引起的。要检查数据库是否损
这是一个非常简单的问题,但我似乎找不到在某些情况下选择一个而不是另一个的一般规则。 假设我有一个简单的 Point 类,如下所示: class Point { public: Point();
这个问题在这里已经有了答案: Java Programming - Where should SQL statements be stored? [closed] (15 个答案) 关闭 9 年前。
我很欣赏这个问题可能有点“基于意见”,但是,我认为一个概括的答案可以极大地帮助将来有兴趣了解更多关于 PWA 和 Service Workers 的其他人。 背景 我在网上搜索过,但很惊讶地发现没有明
对于编程语言解释器,我想知道解释器经历的事件顺序。例如,我认为事情是这样的: 解释器得到一些输入 词法分析器/分词器获取输入并划分标记 x 获取代币列表 ??? 代码被执行 什么步骤属于 ??? sp
我是 Flutter 的新手,刚刚从阅读有关 Flutter 的教程中听说了 BLoC 概念。从这里 tutorial ,第一次听说BLoC。但是我在这篇文章中也看到了一个名为“Repository”
我正在为下/上三角矩阵(double)编写一个类。通过利用 n*n 三角矩阵只有 n*(n + 1)/2 [可能非零] 元素这一事实,我在内部只存储平面数组成员中的元素数量。 首先,我有一个“普通”(
我有一个 Java src 文件夹,我在其中存储我的 .java 文件。然后我使用终端编译它们并最终在同一目录中获得 .class 文件。这不一定会打扰我,但我从未见过专业人士这样做。 按照专业惯例(
我是一名优秀的程序员,十分优秀!