ActiveMQ入门实例
1.下載ActiveMQ
去官方網(wǎng)站下載:http://activemq.apache.org/
2.運(yùn)行ActiveMQ
解壓縮apache-activemq-5.5.1-bin.zip,然后雙擊apache-activemq-5.5.1\bin\activemq.bat運(yùn)行ActiveMQ程序。
啟動(dòng)ActiveMQ以后,登陸:http://localhost:8161/admin/,創(chuàng)建一個(gè)Queue,命名為FirstQueue。
3.創(chuàng)建Eclipse項(xiàng)目并運(yùn)行
創(chuàng)建project:ActiveMQ-5.5,并導(dǎo)入apache-activemq-5.5.1\lib目錄下需要用到的jar文件,項(xiàng)目結(jié)構(gòu)如下圖所示
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 用它創(chuàng)建連接ConnectionFactory connectionFactory;// Connection :JMS 客戶端到JMS Provider 的連接Connection connection = null;// Session: 一個(gè)發(fā)送或接收消息的線程Session session;// Destination :消息的目的地;消息發(fā)送給誰.Destination destination;// MessageProducer:消息發(fā)送者M(jìn)essageProducer producer;// TextMessage message;// 構(gòu)造ConnectionFactory實(shí)例對(duì)象,此處采用ActiveMq的實(shí)現(xiàn)jarconnectionFactory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER,ActiveMQConnection.DEFAULT_PASSWORD,"tcp://localhost:61616");try {// 構(gòu)造從工廠得到連接對(duì)象connection = connectionFactory.createConnection();// 啟動(dòng)connection.start();// 獲取操作連接session = connection.createSession(Boolean.TRUE,Session.AUTO_ACKNOWLEDGE);// 獲取session注意參數(shù)值xingbo.xu-queue是一個(gè)服務(wù)器的queue,須在在ActiveMq的console配置destination = session.createQueue("FirstQueue");// 得到消息生成者【發(fā)送者】producer = session.createProducer(destination);// 設(shè)置不持久化,此處學(xué)習(xí),實(shí)際根據(jù)項(xiàng)目決定producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);// 構(gòu)造消息,此處寫死,項(xiàng)目就是參數(shù),或者方法獲取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 發(fā)送的消息" + i);// 發(fā)送消息到目的地方System.out.println("發(fā)送消息:" + "ActiveMq 發(fā)送的消息" + 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 用它創(chuàng)建連接ConnectionFactory connectionFactory;// Connection :JMS 客戶端到JMS Provider 的連接Connection connection = null;// Session: 一個(gè)發(fā)送或接收消息的線程Session session;// Destination :消息的目的地;消息發(fā)送給誰.Destination destination;// 消費(fèi)者,消息接收者M(jìn)essageConsumer consumer;connectionFactory = new ActiveMQConnectionFactory(ActiveMQConnection.DEFAULT_USER,ActiveMQConnection.DEFAULT_PASSWORD,"tcp://localhost:61616");try {// 構(gòu)造從工廠得到連接對(duì)象connection = connectionFactory.createConnection();// 啟動(dòng)connection.start();// 獲取操作連接session = connection.createSession(Boolean.FALSE,Session.AUTO_ACKNOWLEDGE);// 獲取session注意參數(shù)值xingbo.xu-queue是一個(gè)服務(wù)器的queue,須在在ActiveMq的console配置destination = session.createQueue("FirstQueue");consumer = session.createConsumer(destination);while (true) {//設(shè)置接收者接收消息的時(shí)間,為了便于測試,這里誰定為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.注意事項(xiàng)
最后接收者跟發(fā)送者在不同的機(jī)器上測試
項(xiàng)目所引用的jar最后在ActiveMQ下的lib中找,這樣不會(huì)出現(xiàn)版本沖突。
5.測試過程
因?yàn)槭窃趩螜C(jī)上測試,所以需要開啟兩個(gè)eclipse,每一個(gè)eclipse都有自身的workspace。我們?cè)趀clipse1中運(yùn)行Receiver,在eclipse2中運(yùn)行Sender。
剛開始eclipse1中運(yùn)行Receiver以后console介面沒有任何信息,在eclipse2中運(yùn)行Sender以后,eclipse2中的console顯示如下信息:
發(fā)送消息:ActiveMq 發(fā)送的消息1
發(fā)送消息:ActiveMq 發(fā)送的消息2
發(fā)送消息:ActiveMq 發(fā)送的消息3
發(fā)送消息:ActiveMq 發(fā)送的消息4
發(fā)送消息:ActiveMq 發(fā)送的消息5
而回到eclipse1中發(fā)現(xiàn)console界面出現(xiàn)如下信息:
收到消息ActiveMq 發(fā)送的消息1
收到消息ActiveMq 發(fā)送的消息2
收到消息ActiveMq 發(fā)送的消息3
收到消息ActiveMq 發(fā)送的消息4
收到消息ActiveMq 發(fā)送的消息5
今天發(fā)現(xiàn)測試并不需要開啟兩個(gè)eclipse,在一個(gè)eclipse下頁可以啟動(dòng)多個(gè)程序,并且有多個(gè)console,在上面的Receiver.java中,設(shè)置一個(gè)較大的時(shí)間,比如receive(500000),如下代碼所示:
TextMessage message = (TextMessage) consumer.receive(500000);
這個(gè)時(shí)候運(yùn)行Receiver.java的話,會(huì)使得這個(gè)Receiver.java一直運(yùn)行500秒,在eclipse中可以發(fā)現(xiàn):
點(diǎn)擊那個(gè)紅色方塊可以手動(dòng)停止運(yùn)行程序。
運(yùn)行玩receiver以后我們?cè)谶\(yùn)行sender,在運(yùn)行完sender以后,我們要切換到receiver的console,如下圖所示:
轉(zhuǎn)載于:https://www.cnblogs.com/mengyuxin/p/5753376.html
總結(jié)
以上是生活随笔為你收集整理的ActiveMQ入门实例的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php中mysql和mysqli_php
- 下一篇: 5个值得安利的PC软件,建议收藏转发