1. JMS 入门小 Demo 1.1 点对点模式点对点的模式主要建立在一个队列上面,当连接一个列队的时候,发送端不需要知道接收端是否正在接收,可以直接向 ActiveMQ 发送消息,发送的消息,将会先进入队列中,如果有接收端在监听,则会发向接收端,如果没有接收端接收,则会保存在 activemq 服务器, 直到接收端接收消息,点对点的消息模式可以有多个发送端,多个接收端,但是一条消息, 只会被一个接收端给接收到,哪个接收端先连上 ActiveMQ,则会先接收到,而后来的接收端则接收不到那条消息。 1.1.1 消息生产者 (1)创建工程 jmsDemo ,引入依赖 [AppleScript] 纯文本查看 复制代码 <dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-client</artifactId>
<version>5.13.4</version>
</dependency> (2)创建类 QueueProducer main 方法代码如下: [AppleScript] 纯文本查看 复制代码 //1.创建连接工厂
ConnectionFactory connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
//2.获取连接
Connection connection = connectionFactory.createConnection();
//3.启动连接connection.start();
//4.获取 session (参数 1:是否启动事务,参数 2:消息确认模式)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//5.创建队列对象
Queue queue = session.createQueue("test-queue");
//6.创建消息生产者
MessageProducer producer = session.createProducer(queue);
//7.创建消息
TextMessage textMessage = session.createTextMessage("欢迎来到神奇的品优购世界");
//8.发送消息producer.send(textMessage);
//9.关闭资源
producer.close(); session.close();
connection.close(); 上述代码中第 4 步创建 session 的两个参数: 第 1 个参数 是否使用事务第 2 个参数 消息的确认模式 · AUTO_ACKNOWLEDGE = 1 自动确认 · CLIENT_ACKNOWLEDGE = 2 客户端手动确认 · DUPS_OK_ACKNOWLEDGE = 3 自动批量确认 · SESSION_TRANSACTED = 0 事务提交并确认运行后通过 ActiveMQ 管理界面查询 1.1.1 消息消费者 创建类 QueueConsumer ,main 方法代码如下: [AppleScript] 纯文本查看 复制代码 //1.创建连接工厂
ConnectionFactory connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
//2.获取连接
Connection connection = connectionFactory.createConnection();
//3.启动连接connection.start();
//4.获取 session (参数 1:是否启动事务,参数 2:消息确认模式)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//5.创建队列对象
Queue queue = session.createQueue("test-queue");
//6.创建消息消费
MessageConsumer consumer = session.createConsumer(queue);
//7.监听消息
consumer.setMessageListener(new MessageListener() {
public void onMessage(Message message) { TextMessage textMessage=(TextMessage)message; try {
System.out.println("接收到消息:"+textMessage.getText());
} catch (JMSException e) {
// TODO Auto-generated catch block e.printStackTrace();
}
}
});
//8.等待键盘输入System.in.read();
//9.关闭资源
consumer.close(); session.close();
connection.close(); 执行后看到控制台输出 1.1.1 运行测试 同时开启 2 个以上的消费者,再次运行生产者,观察每个消费者控制台的输出,会发现只有一个消费者会接收到消息。 2.2 发布/订阅模式 2.2.1 消息生产者 创建类 TopicProducer ,main 方法代码如下: [AppleScript] 纯文本查看 复制代码 //1.创建连接工厂
ConnectionFactory connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
//2.获取连接
Connection connection = connectionFactory.createConnection();
//3.启动连接connection.start();
//4.获取 session (参数 1:是否启动事务,参数 2:消息确认模式)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//5.创建主题对象
Topic topic = session.createTopic("test-topic");
//6.创建消息生产者
MessageProducer producer = session.createProducer(topic);
//7.创建消息
TextMessage textMessage = session.createTextMessage("欢迎来到神奇的品优购世界");
//8.发送消息producer.send(textMessage); [AppleScript] 纯文本查看 复制代码 //9.关闭资源
producer.close();
session.close(); connection.close(); 运行效果如下: 2.2.1 消息消费者 创建类 TopicConsumer ,main 方法代码如下: [AppleScript] 纯文本查看 复制代码 //1.创建连接工厂
ConnectionFactory connectionFactory=new ActiveMQConnectionFactory("tcp://192.168.25.135:61616");
//2.获取连接
Connection connection = connectionFactory.createConnection();
//3.启动连接connection.start();
//4.获取 session (参数 1:是否启动事务,参数 2:消息确认模式)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//5.创建主题对象
//Queue queue = session.createQueue("test-queue"); Topic topic = session.createTopic("test-topic");
//6.创建消息消费
MessageConsumer consumer = session.createConsumer(topic);
//7.监听消息
consumer.setMessageListener(new MessageListener() {
public void onMessage(Message message) { TextMessage textMessage=(TextMessage)message; try {
System.out.println("接收到消息:"+textMessage.getText());
} catch (JMSException e) {
// TODO Auto-generated catch block e.printStackTrace();
}
}
});
//8.等待键盘输入System.in.read();
//9.关闭资源
consumer.close(); session.close(); connection.close(); 2.2.1 运行测试 同时开启 2 个以上的消费者,再次运行生产者,观察每个消费者控制台的输出,会发现每个消费者会接收到消息。
|