我是JMS的新手并使用Jdeveloper和Weblogic 12c,我的代码运行良好但是Consumer onMessage()
方法没有收到来自Producer的任何消息。虽然我没有使用onMessage()
时可以收到消息。我必须在它运行之前配置任何文件吗?
这是消息使用者代码
package com.soap_jms;
import javax.jms.ExceptionListener;
import java.util.*;
import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.Queue;
import javax.jms.Session;
import javax.jms.TextMessage;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.naming.Context;
import utils.system;
public class QueueConsume implements MessageListener, ExceptionListener{
private final static String JMS_FACTORY="jms/ThesisConnectionFactory";
private final static String QUEUE="jms/ThesisJMSQueue";
private static Connection mConnection;
private static ConnectionFactory mConnectionFactory;
private static Queue mQueue;
private static MessageConsumer mConsumer;
private static Session mSession;
public static void main (String [] args) throws JMSException, NamingException {
mConnection=null;
MessageListener listener = null;
System.out.println("Entering into JMS Queue Consumer........");
Context ctx = QueueConsume.getInitialContext();
mConnectionFactory=(javax.jms.ConnectionFactory)ctx.lookup(JMS_FACTORY);
mQueue=(javax.jms.Queue)ctx.lookup(QUEUE);
mConnection=mConnectionFactory.createConnection();
mSession=mConnection.createSession(false,Session.AUTO_ACKNOWLEDGE);
mConsumer=mSession.createConsumer(mQueue);
QueueConsume mConsume = new QueueConsume();
mConsumer.setMessageListener(mConsume);
mConnection.setExceptionListener(mConsume);
mConnection.start();
System.out.println("JMS is set to accept sent message.....");
System.out.println("Exiting from JMS Queue Consumer ........");
close();
} // closes main method
@SuppressWarnings("oracle.jdeveloper.java.insufficient-catch-block")
public void onMessage(Message message) {
try {
System.out.println("Message is " + ((TextMessage) message).getText());
} catch (JMSException e) {
}
}
@SuppressWarnings("oracle.jdeveloper.java.unchecked-conversion-or-cast")
public static Context getInitialContext() throws JMSException, NamingException {
Hashtable htb = new Hashtable();
htb.put(Context.INITIAL_CONTEXT_FACTORY,"weblogic.jndi.WLInitialContextFactory");
htb.put(Context.PROVIDER_URL,"t3://localhost:7101");
Context ctx= new InitialContext(htb);
return ctx;
}
public static void close() throws JMSException {
mSession.close();
mConnection.close();
mConsumer.close();
}
public void onException(JMSException exception)
{
System.err.println("an error occurred: " + exception);
}
}
答案 0 :(得分:1)
我怀疑问题是因为主线程在调用onMessage
方法之前结束。调用Connection.start()
方法后,您正在调用close
。通常,setMessageListener是一个异步操作,因此调用立即返回,但onMessage
线程的实际启动并行发生。建议你在onMessage
线程接收消息时让一些睡眠或其他方式使主线程等待。