A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

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 个以上的消费者,再次运行生产者,观察每个消费者控制台的输出,会发现每个消费者会接收到消息。

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马