我编写了一个示例代码,用于向activemq添加元素,然后检索它们。我成功地添加了大约1000个元素,但是在检索元素时,在检索大约50 - 200个元素之后,某些代码会被卡住,即使队列中有很多元素。
以下是我用于向队列添加元素的代码
@POST
@Path("/addelementtoqueue")
@Consumes(MediaType.APPLICATION_FORM_URLENCODED)
public void addElementToQeueue(@FormParam("count") int count) throws Exception {
IntStream.range(0, count)
.forEach(e -> {
try {
addElement(e);
}catch(Exception e1) {
throw new RuntimeException(e1);
}
});
}
private void addElement(int i) throws Exception {
Connection conn = GlobalConfiguration.getJMSConnectionFactory().createConnection();
conn.start();
Session session = conn.createSession(false, Session.CLIENT_ACKNOWLEDGE);
MessageProducer prod = session.createProducer(queue);
prod.send(queue, session.createTextMessage("message "+ i), DeliveryMode.PERSISTENT, 4, 0);
prod.close();
session.close();
conn.close();
}
这是我用来从队列中检索元素的代码片段
@POST
@Path("/removeelementfromqueue")
@Consumes(MediaType.APPLICATION_FORM_URLENCODED)
public void removeElementToQeueue(@FormParam("count") int count) throws Exception {
IntStream.range(0, count)
.forEach(e -> {
try {
extractElement();
}catch(Exception e1) {
throw new RuntimeException(e1);
}
});
}
private void extractElement() throws Exception {
Connection conn = GlobalConfiguration.getJMSConnectionFactory().createConnection();
conn.start();
Session session = conn.createSession(false, Session.CLIENT_ACKNOWLEDGE);
queue = session.createQueue("walkin.testing");
MessageConsumer consumer = session.createConsumer(queue);
TextMessage msg = (TextMessage)consumer.receive();
System.out.println(msg.getText());
msg.acknowledge();
consumer.close();
session.close();
conn.close();
}
我通过resource.xml获取连接工厂,相同的代码片段是
<resources>
<Resource id="MyJmsResourceAdapter" type="ActiveMQResourceAdapter">
BrokerXmlConfig = jdbcBroker:(tcp://0.0.0.0:61616)
ServerUrl = tcp://0.0.0.0:61616?jms.prefetchPolicy.queuePrefetch=0
</Resource>
<Resource id="MyJmsConnectionFactory" type="javax.jms.ConnectionFactory">
ResourceAdapter = MyJmsResourceAdapter
</Resource></resources>
我正在使用activeMQ 5.13.1,apache-tomee-plus-1.7.2和Java 8,jdbc存储为mysql。我已将activemq-jdbc-performance.xml配置为apache activemq的配置文件。
我已尝试过对此进行大量研究,但我无法确定此问题的根本原因。如果有人能告诉我我做错了什么,这将非常有帮助
答案 0 :(得分:0)
我建议不要为每个操作打开/关闭连接/会话/队列,而是可以使用池来最小化每个资源需要的数量。非常确定连接是线程安全的,但会话不是,您需要为每个活动线程创建/使用/专用会话。通过池化,您可以最小化创建的会话数,但当前正在运行的活动线程将在以后重复使用。
所以我假设你遇到了资源问题,即使看起来所有内容都被正确关闭/释放,但事情并非如此(可能在我看到的代码之外)。你检查过activemq日志了吗?您是否通过此调试并确保在尝试创建第n个连接或会话时它没有挂起?