1、創建maven項目,導入pom.xml依賴包
<!--activemq所需依賴jar配置-->
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-all</artifactId>
<version>5.15.9</version>
</dependency>
2、JmsProduce.java 生產者
/**
* 生產者
*/
public class JmsProduce {
//工廠連接地址
private static final String ACTIVEMQ_URL = "tcp://192.168.150.131:61616";
//隊列名稱
private static final String QUEUE_NAME = "queue01";
public static void main(String[] args) throws JMSException {
//1、創建連接工廠,按照給定的url,採用默認的用戶名和密碼
ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(ACTIVEMQ_URL);
//2、通過連接工廠獲得連接connection並啓動訪問
Connection connection = activeMQConnectionFactory.createConnection();
connection.start();
//3、創建會話 兩個參數:第一個(事務),第二個(簽收)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//4、創建目的地(隊列還是主題),先創建隊列
//Destination destination = session.createQueue(QUEUE_NAME); //父接口 目的地:(包括隊列和主題)
Queue queue = session.createQueue(QUEUE_NAME);
//5、創建消息的生產者
MessageProducer messageProducer = session.createProducer(queue);
//6、通過使用消息生產者生產10條消息發送到MQ隊列裏面
for (int i = 1; i <=10 ; i++) {
//7、創建消息
TextMessage textMessage = session.createTextMessage("msg---" + i);//理解爲一個字符串
//8、通過消息生產者(MessageProducer)發送給MQ
messageProducer.send(textMessage);
}
//9、關閉資源
messageProducer.close();
session.close();
connection.close();
System.out.println("消息發送完成!");
}
}
3、JmsConsumer.java 消費者 (同步阻塞方式)
/**
* 消費者 (同步阻塞方式)
*/
public class JmsConsumer {
//工廠連接地址
private static final String ACTIVEMQ_URL = "tcp://192.168.150.131:61616";
//隊列名稱
private static final String QUEUE_NAME = "queue01";
public static void main(String[] args) throws JMSException {
//1、創建連接工廠,按照給定的url,採用默認的用戶名和密碼
ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(ACTIVEMQ_URL);
//2、通過連接工廠獲得連接connection並啓動訪問
Connection connection = activeMQConnectionFactory.createConnection();
connection.start();
//3、創建會話 兩個參數:第一個(事務),第二個(簽收)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//4、創建目的地(隊列還是主題),先創建隊列
//Destination destination = session.createQueue(QUEUE_NAME); //父接口 目的地:(包括隊列和主題)
Queue queue = session.createQueue(QUEUE_NAME);
//5、創建消費者
MessageConsumer messageConsumer = session.createConsumer(queue);
while (true){
//消費方式: 死等receive()和 超時等receive(5000L)
TextMessage textMessage = (TextMessage) messageConsumer.receive(5000L); //裝換類型,同一種格式
if(null != textMessage){
System.out.println("消費者接受到消息:"+textMessage.getText());
}else {
break;
}
}
//6、倒着關閉資源
messageConsumer.close();
session.close();
connection.close();
}
}
4、JmsConsumerMonitor.java 消費者 異步非阻塞方式(監聽方式)
/**
* 消費者 異步非阻塞方式(監聽方式)
*/
public class JmsConsumerMonitor {
//工廠連接地址
private static final String ACTIVEMQ_URL = "tcp://192.168.150.131:61616";
//隊列名稱
private static final String QUEUE_NAME = "queue01";
public static void main(String[] args) throws JMSException, IOException {
System.out.println("我是2號消費者......");
//1、創建連接工廠,按照給定的url,採用默認的用戶名和密碼
ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(ACTIVEMQ_URL);
//2、通過連接工廠獲得連接connection並啓動訪問
Connection connection = activeMQConnectionFactory.createConnection();
connection.start();
//3、創建會話 兩個參數:第一個(事務),第二個(簽收)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//4、創建目的地(隊列還是主題),先創建隊列
//Destination destination = session.createQueue(QUEUE_NAME); //父接口 目的地:(包括隊列和主題)
Queue queue = session.createQueue(QUEUE_NAME);
//5、創建消費者
MessageConsumer messageConsumer = session.createConsumer(queue);
//6、通過監聽的方式
messageConsumer.setMessageListener(new MessageListener(){
@Override
public void onMessage(Message message) {
if(null != message && message instanceof TextMessage){
TextMessage textMessage = (TextMessage) message;
try {
System.out.println("消費者接受到消息:"+textMessage.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}
});
System.in.read(); //保證控制檯不滅,一直輸出
messageConsumer.close();
session.close();
connection.close();
}
}
5、兩個消費者監聽着同一個隊列:效果圖
當生產者發送消息的時候,兩個消費者消費方式類似於輪訓的方式,一人消費一半
控制檯打印: