之前一直没有用过消息中间件,但是很多公司都问是否用过这一类的技术,所以花了几天时间,大致看了一下,写了一个简单的demo.
仅供入门参考,仅供入门参考,仅供入门参考,重要的事说三次!!!
下面直接上代码,注释都很详细(自行百度所需jar包):
首先是生产者
import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
/**
* 生产者
* @author 李小拐 2016年11月12日 12:37:09
*
*/
public class JMSProducter {
//默认连接用户名
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;
//默认连接密码
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;
//默认连接地址
private static final String BROKEURL = ActiveMQConnection.DEFAULT_BROKER_URL;
//发送的消息数量
private static final int SENDNUM = 10;
public static void main(String[] args) {
ConnectionFactory connectionFactory;//连接工厂
Connection connection=null;//连接
Session session=null;//会话--发送消息的线程
Destination destination;//消息目的地
MessageProducer messageProducer;//消息生产者
//实例化连接工厂
connectionFactory=new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKEURL);
try {
//通过连接工厂获取连接
connection=connectionFactory.createConnection();
//启动连接
connection.start();
//创建session
session=connection.createSession(true, Session.AUTO_ACKNOWLEDGE);
//创建一个名为“test”的消息他、队列
destination=session.createQueue("test");
//创建消息生产者
messageProducer=session.createProducer(destination);
//发送消息
sendMessage(session, messageProducer);
session.commit();
} catch (JMSException e) {
e.printStackTrace();
}finally{
if(connection!=null){
try {
connection.close();
} catch (JMSException e) {
e.printStackTrace();
}
}
}
}
/*
* 发送消息的方法
*/
public static void sendMessage(Session session,MessageProducer messageProducer) throws JMSException {
for (int i = 0; i < SENDNUM; i++) {
//创建一个文本消息
//除此之外还有其他类型的消息,比如对象,xml,键值对等等
TextMessage message=session.createTextMessage("这是生产者--"+i+"--发送的消息");
System.out.println("生产者:发送消息=="+i);
//通过消息生产者发送消息
messageProducer.send(message);
}
}
}
其次是消费者:
import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import javax.jms.TextMessage;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
/*
* 消费者,消息的接收者
*/
public class JMSConsumer {
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;//默认连接用户名
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;//默认连接密码
private static final String BROKEURL = ActiveMQConnection.DEFAULT_BROKER_URL;//默认连接地址
/**
* @param args
*/
public static void main(String[] args) {
ConnectionFactory connectionFactory;//连接工厂
Connection connection;//连接
Session session;//会话
Destination destination;//消费者的消息来源===生产者的消息目的地
MessageConsumer messageConsumer;//消费者
//实例化连接工厂
connectionFactory=new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKEURL);
try {
//从连接工厂获取一个连接
connection=connectionFactory.createConnection();
//启动连接
connection.start();
//创建session
session=connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//创建一个接受“test”消息的队列
destination=session.createQueue("test");
//创建消息消费者
messageConsumer=session.createConsumer(destination);
//通过监听器来消费消息
messageConsumer.setMessageListener(new JMSListener());
// while (true) {
// TextMessage textMessage=(TextMessage)messageConsumer.receive();
// if(textMessage!=null){
// System.out.println("recive::::"+textMessage);
// }else {
// break;
// }
// }
} catch (JMSException e) {
e.printStackTrace();
}
}
}
最后是监听器:
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage;
/**
* 消息监听器
* @author 李小拐 2016年11月12日 12:39:26
*
*/
public class JMSListener implements MessageListener{
@Override
public void onMessage(Message message) {
TextMessage textMessage=(TextMessage)message;
try {
System.out.println("接收到的消息:"+textMessage.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}