我已经实现了Oracle高级队列&我在写一个监听器程序。下面是我的示例:MessageListener不在Oracle队列中收听消息
package com.myprog;
import java.io.File;
import java.io.FileInputStream;
import java.io.StringWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.util.Properties;
import javax.jms.ExceptionListener;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.Session;
import javax.jms.TextMessage;
import oracle.jms.AQjmsFactory;
import oracle.jms.AQjmsSession;
import org.apache.log4j.Logger;
public class abc implements MessageListener, ExceptionListener {
private static String queueUserName = "admin";
private static String queueName = "my_queue";
// Initialize the logger
private static Logger log = Logger.getLogger(abc.class);
public static void main(String[] args) {
final String METHOD_NAME = "main()";
abc a = new abc();
Queue queue;
try {
QueueConnection QCon = getConnection();
Session session = QCon.createQueueSession(false, Session.AUTO_ACKNOWLEDGE);
QCon.start();
queue = ((AQjmsSession) session).getQueue(queueUserName, queueName);
MessageConsumer consumer = session.createConsumer(queue);
consumer.setMessageListener(a);
QCon.setExceptionListener(a);
consumer.close();
session.close();
QCon.close();
} catch (JMSException e) {
e.printStackTrace();
}
}
public static QueueConnection getConnection() {
String hostname = "myhost";
String oracle_sid = "mysid";
int portno = 1521;
String userName = "myapp";
String password = "pwd";
String driver = "thin";
QueueConnectionFactory QFac = null;
QueueConnection QCon = null;
try {
// get connection factory , not going through JNDI here
QFac = AQjmsFactory.getQueueConnectionFactory(hostname, oracle_sid, portno,driver);
// create connection
QCon = QFac.createQueueConnection(userName, password);
} catch (Exception e) {
e.printStackTrace();
}
return QCon;
}
@Override
public void onException(JMSException e) {
log.error(e);
}
@Override
public void onMessage(Message message) {
TextMessage msg = (TextMessage) message;
try {
String m = msg.getText();
System.out.println("m="+m);
log.info("MESSAGE RECEIVED " + m);
} catch (JMSException e) {
log.error(e);
}
}
}
请注意,此计划是一个独立的程序将继续运行&听在Oracle队列中的消息。
不幸的是,当我创建这个类文件&来看,它的罐子,它只是运行&然后退出&在队列中仅消耗1消息。为什么听众不能继续在队列中运行&?
我以为它会继续收听&检索队列中的所有消息&然后将永远保持在侦听模式,但它不会那样表现。
欣赏是否有人能告诉我发生了什么问题。
感谢
尝试从try块的开头将所有代码封装到块的末尾(true),这样一旦它消耗了一条消息,它就会再次运行该队列的所有设置,并且正在等待另一条消息。我认为在处理每条消息之后,您可能必须创建该会话,因为它处于主要状态。这可能不是永久的解决方案,但现在可能会得到解决。 – Logan 2012-01-08 04:12:14
@Logan,哪个尝试块是你指的?它是主要方法吗? – Mike 2012-01-08 04:19:44
是的,对不起。主要方法之一。 – Logan 2012-01-08 04:34:24