日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ActiveMQ入门实例

發布時間:2023/12/10 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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入门实例的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。