e3-manager-server工程中发送消息。
当商品添加完成后发送一个TextMessage,包含一个商品id。
package cn.e3mall.activemq;
import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.MessageProducer;
import javax.jms.Queue;
import javax.jms.Session;
import javax.jms.TextMessage;
import javax.jms.Topic;
import org.apache.activemq.ActiveMQConnectionFactory;
import org.junit.Test;
public class ActiveMqTest {
/**
* 点到点形式发送消息
*
* @throws Exception
*/
@Test
public void testQueueProducer() throws Exception {
// 1、创建一个连接工厂对象、需要指定服务的ip及端口
ConnectionFactory factory = new ActiveMQConnectionFactory("tcp://192.168.25.128:61616");
// 2、使用工厂对象创建一个Connection对象
Connection connection = factory.createConnection();
// 3、开启连接,调用Connection对象start方法
connection.start();
// 4、创建一个Session对象
// 第一个参数:是否开启事务。如果开启事务,第二个参数无意义。一般不开启事务。
// 第二个参数:应答模式。自动应答或者手动应答。一般自动应答。
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
// 5、使用Session对象创建一个Destination对象。两种形式queue、topic。现在应该使用queue
Queue queue = session.createQueue("test-queue");
// 6、使用Session对象创建一个Producer对象
MessageProducer producer = session.createProducer(queue);
// 7、创建一个Message对象、可以使用TextMessage。
/*
* TextMessage textMessage = new ActiveMQTextMessage();
* textMessage.setText("hello activemq");
*/
TextMessage textMessage = session.createTextMessage("hello activemq");
// 8、发送消息
producer.send(textMessage);
// 9、关闭资源
producer.close();
session.close();
connection.close();
}
@Test
public void testQueueConsumer() throws Exception {
// 创建一个ConnectionFactory对象连接MQ服务器
ConnectionFactory factory = new ActiveMQConnectionFactory("tcp://192.168.25.128:61616");
// 创建一个连接对象
Connection connection = factory.createConnection();
// 开启连接
connection.start();
// 使用Connection对象创建一个Session对象
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
// 创建一个Destination对象。queue对象
Queue queue = session.createQueue("test-queue");
// 使用session创建一个消费者对象
MessageConsumer consumer = session.createConsumer(queue);
// 接收消息
consumer.setMessageListener(new MessageListener() {
@Override
public void onMessage(Message message) {
// 打印结果
TextMessage textMessage = (TextMessage) message;
String text;
try {
text = textMessage.getText();
System.out.println(text);
} catch (Exception e) {
e.printStackTrace();
}
}
});
// 等待接收消息
System.in.read();
// 关闭资源
consumer.close();
session.close();
connection.close();
}
@Test
public void testTopicProducer() throws Exception {
// 1、创建一个连接工厂对象、需要指定服务的ip及端口
ConnectionFactory factory = new ActiveMQConnectionFactory("tcp://192.168.25.128:61616");
// 2、使用工厂对象创建一个Connection对象
Connection connection = factory.createConnection();
// 3、开启连接,调用Connection对象start方法
connection.start();
// 4、创建一个Session对象
// 第一个参数:是否开启事务。如果开启事务,第二个参数无意义。一般不开启事务。
// 第二个参数:应答模式。自动应答或者手动应答。一般自动应答。
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
// 5、使用Session对象创建一个Destination对象。两种形式queue、topic。现在应该使用topic
Topic topic = session.createTopic("test-topic");
// 6、使用Session对象创建一个Producer对象
MessageProducer producer = session.createProducer(topic);
// 7、创建一个Message对象、可以使用TextMessage。
/*
* TextMessage textMessage = new ActiveMQTextMessage();
* textMessage.setText("hello activemq");
*/
TextMessage textMessage = session.createTextMessage("topic message");
// 8、发送消息
producer.send(textMessage);
// 9、关闭资源
producer.close();
session.close();
connection.close();
}
@Test
public void testTopicConsumer() throws Exception {
// 创建一个ConnectionFactory对象连接MQ服务器
ConnectionFactory factory = new ActiveMQConnectionFactory("tcp://192.168.25.128:61616");
// 创建一个连接对象
Connection connection = factory.createConnection();
// 开启连接
connection.start();
// 使用Connection对象创建一个Session对象
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
// 创建一个Destination对象。topic对象
Topic topic = session.createTopic("test-topic");
// 使用session创建一个消费者对象
MessageConsumer consumer = session.createConsumer(topic);
// 接收消息
consumer.setMessageListener(new MessageListener() {
@Override
public void onMessage(Message message) {
// 打印结果
TextMessage textMessage = (TextMessage) message;
String text;
try {
text = textMessage.getText();
System.out.println(text);
} catch (Exception e) {
e.printStackTrace();
}
}
});
System.out.println("topic消费者3启动。。。");
// 等待接收消息
System.in.read();
// 关闭资源
consumer.close();
session.close();
connection.close();
}
}
queue模式:发送了消息,如果没有消费者来消费,这个消息是会保存在mq里。
topic模式:发送了消息,如果没有消费者来消费,这个消息就不会保存在mq里。
test的一个方法可以运行多次,这样,就会有多个线程运行。
activemq广播形式也是可以持久化的。如果,没有消费,就一直保存。