【问题标题】:java multi-threaded jms queue receiverjava多线程jms队列接收器
【发布时间】:2013-01-14 18:48:25
【问题描述】:

我正在使用 oracle 高级队列 (AQ JMS)。我正在尝试使用多个线程来使用 QueueReceiver 来消耗 jms 队列。

问题:该模型分叉了多个线程,但性能仍接近单线程模型。如何增加队列消耗?

以下是代码片段:

final QueueReceiver queueReceiver = getQueueReceiver(queueSession);
        qConn.start();
        //THREAD POOL SIZE
        final int threadPoolSize = getThreadCount();


        final ExecutorService executor = Executors.newFixedThreadPool(threadPoolSize);

        for (int i = 0; i < threadPoolSize; i++) {
            executor.submit(new MessageWorker(queueReceiver));
        }

消息工作者代码如下所示:

    class MessageWorker extends Thread {
    MessageConsumer messageConsumer;

    public MessageWorker(MessageConsumer subs) {
        this.messageConsumer = subs;
    }

    /**
     * @see java.lang.Thread#run()
     */
    @Override
    public void run() {
        try {
            while (true) {
                try {
                    Message msg = messageConsumer.receive();
                    if (null != msg) {
                        //log message
                        logMessage(msg);
                        //handle message
                        handleMessage(msg);
                        //ack
                        msg.acknowledge();
                    }
                } catch (JMSException e) {
                    log.error(e);
                }
            }
        } catch (Exception e) {
            log.error(e);
        } finally {
            log.info("Thread:" + this.getName() + " terminated.");
        }
    }

【问题讨论】:

    标签: java multithreading jms


    【解决方案1】:

    每个线程应该有一个单独的 JMS 会话。您的代码 sn-p 中似乎没有为每个线程创建一个会话。

    【讨论】:

    • (MessageConsumer 是使用 Session 实例创建的。)
    • 我修改了代码,让每个worker创建自己的connection、session和receiver,没有任何效果。
    • 无需创建单独的连接。否则,我相信它应该与多个内核一起使用。
    • 生产者的生产速度真的足够快,可以看到差异吗?
    • 使用主题而不是队列的速度更好,但仍然不是很好,你说得对,确认进程会降低性能。我最终添加了后台作业以清除主题中已处理的消息....
    猜你喜欢
    • 2012-01-19
    • 2011-05-02
    • 1970-01-01
    • 2011-06-14
    • 2019-10-08
    • 1970-01-01
    • 1970-01-01
    • 2017-07-02
    • 2014-11-20
    相关资源
    最近更新 更多