[英]java multi-threaded jms queue receiver
我正在使用Oracle Advanced Queuing(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.");
}
}
每個線程應該有一個單獨的JMS會話。 在您的代碼段中似乎沒有為每個線程創建會話。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.