- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Java 应用程序,其中有许多组件通过 JMS (ActiveMQ) 进行通信。目前,应用程序和 JMS Hub 位于同一服务器上,尽管我们最终计划拆分组件以实现可扩展性。我们在性能方面存在重大问题,最值得注意的是,所有这些问题似乎都与 JMS 相关,而这个问题的焦点是向主题发布消息所花费的时间。
我们有大约 50 个动态创建的主题,用于应用程序组件之间的通信。一个组件从表中读取记录并一次处理一条记录,该处理涉及创建一条 JMS 对象消息并将其发布到其中一个主题。此处理无法跟上将记录写入源表的速率~23/秒,因此我们更改了处理以创建 JMS 对象消息并将其添加到队列中。创建了一个新线程,该线程从此队列中读取并将消息发布到适当的主题。显然,这不会加快处理速度,但它确实使我们能够通过查看队列的大小来了解我们落后了多远。
当天开始时,整个系统没有消息通过,这会迅速从第一个小时内通过集线器的 1560000 条(433 条/秒)消息增加到第三个小时内的 2100000 条(582 条/秒)消息,然后保持在那个水平。在第一个小时开始时,从数据库表中读取记录的组件发布的消息保持不变,但是到该小时结束时,队列中有 2000 条消息等待发送,到了第 3 小时,队列中有 9000 条消息其中的消息。
下面是发送 JMS 消息的代码的相应部分。非常感谢任何有关我们做错了什么或如何提高性能的建议。查看网络上的统计数据,JMS 应该能够轻松处理每秒约 1000-2000 条大消息或每秒约 10000 条小消息。我们的消息每条大约 500 字节,所以我想它位于该范围的中间位置。
获取发布者的代码:
private JmsSessionPublisher getJmsSessionPublisher(String topicName) throws JMSException {
if (!this.topicPublishers.containsKey(topicName)) {
TopicSession pubSession = (ActiveMQTopicSession) topicConnection.createTopicSession(false, Session.AUTO_ACKNOWLEDGE);
ActiveMQTopic topic = getTopic(topicName, pubSession);
// Create a JMS publisher and subscriber
TopicPublisher publisher = pubSession.createPublisher(topic);
this.topicPublishers.put(topicName, new JmsSessionPublisher(pubSession, publisher));
}
return this.topicPublishers.get(topicName);
}
发送消息:
JmsSessionPublisher jmsSessionPublisher = getJmsSessionPublisher(topicName);
ObjectMessage objMessage = jmsSessionPublisher.getSession().createObjectMessage(messageObj);
objMessage.setJMSCorrelationID(correlationID);
objMessage.setJMSTimestamp(System.currentTimeMillis());
jmsSessionPublisher.getPublisher().publish(objMessage, false, 4, 0);
将消息添加到队列的代码:
List<EventQueue> events = eventQueueDao.getNonProcessedEvents();
for (EventQueue eventRow : events) {
IEvent event = eventRow.getEvent();
AbstractEventFactory.EventType eventType = AbstractEventFactory.EventType.valueOf(event.getEventType());
String topic = event.getTopicName() + topicSuffix;
EventMsgPayload eventMsg = AbstractEventFactory.getFactory(eventType).getEventMsgPayload(event);
synchronized (queue) {
queue.add(new QueueElement(eventRow.getEventId(), topic, eventMsg));
queue.notify();
}
}
线程中的代码从队列中删除项目:
jmsSessionFactory.publishMessageToTopic(e.getTopic(), e.getEventMsg(), Integer.toString(e.getEventMsg().hashCode()));
publishMessageToTopic
执行上面的“发送消息”代码。
如果一致认为 ActiveMQ 可能不是最佳选择,则可以选择其他 JMS 实现。
最佳答案
并不是 100% 清楚您在哪里遇到性能缓慢的情况,但听起来您所描述的是发布消息的速度缓慢。您每次发布消息时都会创建一个新的发布者吗?如果是这样,那么效率非常低,您应该考虑创建一个发布者并一遍又一遍地使用它来发送消息。此外,如果您要发送持久消息,那么您可能正在使用同步发送到代理。您可能需要考虑使用异步发送来加快速度。有关更多信息,请参阅有关 Async Sends 的文档
另外,消费者的表现如何?有多少消费者正在使用?他们能否跟上消息发布的速度?
此外,您正在使用的代理配置是什么?它已经被调整了吗?
布鲁斯
关于java - JMS (ActiveMQ) 性能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4071509/
场景: private readonly IConnection connection; this.connection = connectionFactory.CreateConnection();
想知道是否可以在 activeMQ 服务器中完成任何配置,将消息从 DLQ 重定向到同一服务器上的另一个队列。 例如。 我有一个队列“MAINQUEUE”,其中有很多消息已激活客户端确认,在处理时如果
我正在 ActiveMQ 中的一个系统上工作,我真的不想丢失消息。我的问题是重试消息导致我的消费者阻塞(而不是处理他们可以处理的消息)。我想给失败的消息几天重试(例如,我的潜在目的地之一是我将通过 S
我们对 AMQ 使用以下配置 定期我有奇怪的问题 - 松散的消息。实际上AMQ说一切正常并且消
我已按照教程安装 ActiveMQ http://servicebus.blogspot.com/2011/02/installing-apache-active-mq-on-ubuntu.html
当我们使用 ActiveMQ 时,我们可以信任 ActiveMQ 服务器的可靠性。例如在开发非实时软件时(不需要立即发送数据。但应该发送)。我们能否信任 activeMQ 作为确认消息传递的可靠来源。
我遇到了 issue使用 ActiveMQ 并希望跟踪/查看所有 ActiveMQ 事件。我能找到的唯一日志文件是与持久数据相关联的(如果打开的话)。我是否查看或生成了任何其他日志文件来告诉我 Act
我们正面临 ActiveMQ 及其使用者的随机问题。我们观察到,即使连接到 ActiveMQ 队列,也很少有消费者没有收到消息。但是在消费者重启后它工作正常。 我们在 ActiveMQ 端有一个名为
有什么方法可以跟踪 ActiveMQ 中的延迟(计划)消息? 我在 AMQ 网络控制台中没有看到任何东西,它们似乎只有在延迟到期时才进入队列……而且我在 JMX 控制台中也找不到它,也许我搜索得不够好
我对Apache ActiveMQ的功能感到困惑。 我从this link下载了ActiveMQ 。所以我这样使用它(环境:Windows 7):我启动 bin/activemq.bat,然后它就可以
我们有一个 ActiveMQ 代理,它使用 JMS、AMQP 和 MQTT 连接到不同的客户端。由于某种原因,我们还没有弄清楚一组特定的 MQTT 客户端经常(并非总是)持久订阅。这是一个测试环境,其
在activemq中有什么方法可以获取消息的数量代理端每秒/每分钟消耗/产生的数量? 我已经尝试使用http://activemq.apache.org/jmeter-performance-test
如何在队列上的 ActiveMQ 中设置 redeliveryPolicy? 1) 在文档中,请参阅:activeMQ Redelivery ,说明您应该在 ConnectionFactory 或 C
我查了一下,它用于在两个系统之间发送消息。 但为什么?为什么不直接使用数据库? 一定有一些 ActiveMQ 具有 数据库 没有的功能吗? 最佳答案 它用于在两个分布式进程之间进行可靠的通信。 是的,
我在生产系统中运行 ActiveMQ。我们的一些队列的流量非常大,而有些队列的流量非常低。我对镜像其中一个低容量队列感兴趣,这样我就可以围绕接收到的消息构建非正式的监控服务。 不幸的是,the onl
我们已经使用此配置为 ActiveMQ Broker 配置了 Broker redelivery 插件。
有什么方法可以检查特定队列是否已存在于 ActiveMQ 中? 最佳答案 http://activemq.apache.org/how-can-i-get-a-list-of-the-topics-a
有人知道如何将 activemq-core.xsd url 与 jar 文件 (activemq-core-5.2.0.jar) 中的 activemq.xsd 关联起来? 我在互联网上找到了一些解决
我是 activemq 的新手。我试图使用 activemq 代理来订阅/发布消息。但至于缺乏经验,我不知道该怎么做,也不知道是否真的可以做到。我在谷歌上搜索了很多,但不幸的是,没有适合此类功能的示例
我一直在努力配置 ActiveMQ 代理,让我感到困惑的一件事是,我读过的所有内容都将 NIO 描述为“如果您需要扩展的不错选择”或“如果您需要更快的速度” ,所以我的问题是他们为什么不说“总是使用
我是一名优秀的程序员,十分优秀!