即使队列不为空,activemq使用者也不会返回数据

时间:2016-02-27 04:36:00

标签: jms activemq java-ee-6 producer-consumer

我编写了一个示例代码,用于向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的配置文件。

我已尝试过对此进行大量研究,但我无法确定此问题的根本原因。如果有人能告诉我我做错了什么,这将非常有帮助

1 个答案:

答案 0 :(得分:0)

我建议不要为每个操作打开/关闭连接/会话/队列,而是可以使用池来最小化每个资源需要的数量。非常确定连接是线程安全的,但会话不是,您需要为每个活动线程创建/使用/专用会话。通过池化,您可以最小化创建的会话数,但当前正在运行的活动线程将在以后重复使用。

所以我假设你遇到了资源问题,即使看起来所有内容都被正确关闭/释放,但事情并非如此(可能在我看到的代码之外)。你检查过activemq日志了吗?您是否通过此调试并确保在尝试创建第n个连接或会话时它没有挂起?

相关问题