ActiveMQ入门实例
1.下載ActiveMQ
去官方網站下載:http://activemq.apache.org/
2.運行ActiveMQ
解壓縮apache-activemq-5.5.1-bin.zip,然后雙擊apache-activemq-5.5.1\bin\activemq.bat運行ActiveMQ程序。
啟動ActiveMQ以后,登陸:http://localhost:8161/admin/,創建一個Queue,命名為FirstQueue。
3.創建Eclipse項目并運行
創建project:ActiveMQ-5.5,并導入apache-activemq-5.5.1\lib目錄下需要用到的jar文件,項目結構如下圖所示
3.1.Sender.java
| package com.xuwei.activemq;import javax.jms.Connection; import javax.jms.ConnectionFactory; import javax.jms.DeliveryMode; import javax.jms.Destination; import javax.jms.MessageProducer; import javax.jms.Session; import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnection; import org.apache.activemq.ActiveMQConnectionFactory;public class Sender {private static final int SEND_NUMBER = 5;public static void main(String[] args) {// ConnectionFactory :連接工廠,JMS 用它創建連接ConnectionFactory connectionFactory;// Connection :JMS 客戶端到JMS Provider 的連接Connection connection = null;// Session: 一個發送或接收消息的線程Session session;// Destination :消息的目的地;消息發送給誰.Destination destination;// MessageProducer:消息發送者MessageProducer producer;// TextMessage message;// 構造ConnectionFactory實例對象,此處采用ActiveMq的實現jarconnectionFactory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER,ActiveMQConnection.DEFAULT_PASSWORD,"tcp://localhost:61616");try {// 構造從工廠得到連接對象connection = connectionFactory.createConnection();// 啟動connection.start();// 獲取操作連接session = connection.createSession(Boolean.TRUE,Session.AUTO_ACKNOWLEDGE);// 獲取session注意參數值xingbo.xu-queue是一個服務器的queue,須在在ActiveMq的console配置destination = session.createQueue("FirstQueue");// 得到消息生成者【發送者】producer = session.createProducer(destination);// 設置不持久化,此處學習,實際根據項目決定producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);// 構造消息,此處寫死,項目就是參數,或者方法獲取sendMessage(session, producer);session.commit();} catch (Exception e) {e.printStackTrace();} finally {try {if (null != connection)connection.close();} catch (Throwable ignore) {}}}public static void sendMessage(Session session, MessageProducer producer)throws Exception {for (int i = 1; i <= SEND_NUMBER; i++) {TextMessage message = session.createTextMessage("ActiveMq 發送的消息" + i);// 發送消息到目的地方System.out.println("發送消息:" + "ActiveMq 發送的消息" + i);producer.send(message);}} } |
3.2.Receiver.java
| package com.xuwei.activemq;import javax.jms.Connection; import javax.jms.ConnectionFactory; import javax.jms.Destination; import javax.jms.MessageConsumer; import javax.jms.Session; import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnection; import org.apache.activemq.ActiveMQConnectionFactory;public class Receiver {public static void main(String[] args) {// ConnectionFactory :連接工廠,JMS 用它創建連接ConnectionFactory connectionFactory;// Connection :JMS 客戶端到JMS Provider 的連接Connection connection = null;// Session: 一個發送或接收消息的線程Session session;// Destination :消息的目的地;消息發送給誰.Destination destination;// 消費者,消息接收者MessageConsumer consumer;connectionFactory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER,ActiveMQConnection.DEFAULT_PASSWORD,"tcp://localhost:61616");try {// 構造從工廠得到連接對象connection = connectionFactory.createConnection();// 啟動connection.start();// 獲取操作連接session = connection.createSession(Boolean.FALSE,Session.AUTO_ACKNOWLEDGE);// 獲取session注意參數值xingbo.xu-queue是一個服務器的queue,須在在ActiveMq的console配置destination = session.createQueue("FirstQueue");consumer = session.createConsumer(destination);while (true) {//設置接收者接收消息的時間,為了便于測試,這里誰定為100sTextMessage message = (TextMessage) consumer.receive(100000);if (null != message) {System.out.println("收到消息" + message.getText());} else {break;}}} catch (Exception e) {e.printStackTrace();} finally {try {if (null != connection)connection.close();} catch (Throwable ignore) {}}} } |
4.注意事項
最后接收者跟發送者在不同的機器上測試
項目所引用的jar最后在ActiveMQ下的lib中找,這樣不會出現版本沖突。
5.測試過程
因為是在單機上測試,所以需要開啟兩個eclipse,每一個eclipse都有自身的workspace。我們在eclipse1中運行Receiver,在eclipse2中運行Sender。
剛開始eclipse1中運行Receiver以后console介面沒有任何信息,在eclipse2中運行Sender以后,eclipse2中的console顯示如下信息:
發送消息:ActiveMq 發送的消息1
發送消息:ActiveMq 發送的消息2
發送消息:ActiveMq 發送的消息3
發送消息:ActiveMq 發送的消息4
發送消息:ActiveMq 發送的消息5
而回到eclipse1中發現console界面出現如下信息:
收到消息ActiveMq 發送的消息1
收到消息ActiveMq 發送的消息2
收到消息ActiveMq 發送的消息3
收到消息ActiveMq 發送的消息4
收到消息ActiveMq 發送的消息5
今天發現測試并不需要開啟兩個eclipse,在一個eclipse下頁可以啟動多個程序,并且有多個console,在上面的Receiver.java中,設置一個較大的時間,比如receive(500000),如下代碼所示:
TextMessage message = (TextMessage) consumer.receive(500000);
這個時候運行Receiver.java的話,會使得這個Receiver.java一直運行500秒,在eclipse中可以發現:
點擊那個紅色方塊可以手動停止運行程序。
運行玩receiver以后我們在運行sender,在運行完sender以后,我們要切換到receiver的console,如下圖所示:
轉載于:https://www.cnblogs.com/mengyuxin/p/5753376.html
總結
以上是生活随笔為你收集整理的ActiveMQ入门实例的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php中mysql和mysqli_php
- 下一篇: 5个值得安利的PC软件,建议收藏转发