ActiveMQ簡(jiǎn)單入門(mén)(新手必看篇)
一、創(chuàng)建一個(gè)簡(jiǎn)單的Hello World案例
首先需要導(dǎo)入activemq-all-5.14.5.jar包,寫(xiě)生產(chǎn)端:
package com.ietree.mq.helloworld; 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.ActiveMQConnectionFactory; public class Sender { public static void main(String[] args) throws Exception { // 第一步:建立ConnectionFactory工廠對(duì)象,需要填入用戶名、密碼、以及要連接的地址,均使用默認(rèn)即可,默認(rèn)端口為:tcp://localhost:61616 ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(ActiveMQConnectionFactory.DEFAULT_USER, ActiveMQConnectionFactory.DEFAULT_PASSWORD, "tcp://localhost:61616"); // 第二步:通過(guò)ConnectionFactory工廠對(duì)象我們創(chuàng)建一個(gè)Connection鏈接,并且調(diào)用ConnectionFactory的start方法開(kāi)啟鏈接,Connection默認(rèn)是關(guān)閉的 Connection connection = connectionFactory.createConnection(); connection.start(); // 第三步:通過(guò)Connection對(duì)象創(chuàng)建Session會(huì)話(上下文環(huán)境對(duì)象),用于接收消息,參數(shù)配置1為是否啟用事務(wù),參數(shù)配置2為簽收模式,一般我們?cè)O(shè)置為自動(dòng)簽收 Session session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE); // 第四步:通過(guò)Session創(chuàng)建Destination對(duì)象,指的是一個(gè)客戶端用來(lái)指定生產(chǎn)消息目標(biāo)和消費(fèi)信息來(lái)源的對(duì)象,在PTP模式中,Destination被稱作Queue即隊(duì)列;在Pub/Sub模式,Destination被稱作Topic即主題。在程序中可以使用多個(gè)Queue和Topic。 Destination destination = session.createQueue("queue1"); // 第五步:我們需要通過(guò)Session對(duì)象創(chuàng)建消息的發(fā)送和接收對(duì)象(生產(chǎn)者和消費(fèi)者)MessageProducer/MessageConsumer。 MessageProducer messageProducer = session.createProducer(destination); // 第六步:我們可以使用MessageProducer的setDeliveryMode方法為其設(shè)置持久化特性和非持久化特性(DeliveryMode) messageProducer.setDeliveryMode(DeliveryMode.NON_PERSISTENT); // 第七步:最后我們使用JMS規(guī)范的TextMessage形式創(chuàng)建數(shù)據(jù)(通過(guò)Session對(duì)象),并用MessageProducer的send方法發(fā)送數(shù)據(jù)。同理,客戶端使用receive方法進(jìn)行接收數(shù)據(jù),最后需要關(guān)閉Connection連接。 for (int i = 0; i < 5; i++) { TextMessage textMessage = session.createTextMessage(); textMessage.setText("我是消息內(nèi)容......" + i); messageProducer.send(textMessage); System.out.println("生產(chǎn)者:" + textMessage.getText()); } if (connection != null) { connection.close(); } } }
寫(xiě)消費(fèi)端:
package com.ietree.mq.helloworld; 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.ActiveMQConnectionFactory; public class Receiver { public static void main(String[] args) throws Exception { // 第一步:建立ConnectionFactory工廠對(duì)象,需要填入用戶名、密碼、以及要連接的地址,均使用默認(rèn)即可,默認(rèn)端口為:tcp://localhost:61616 ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(ActiveMQConnectionFactory.DEFAULT_USER, ActiveMQConnectionFactory.DEFAULT_PASSWORD, "tcp://localhost:61616"); // 第二步:通過(guò)ConnectionFactory工廠對(duì)象我們創(chuàng)建一個(gè)Connection鏈接,并且調(diào)用ConnectionFactory的start方法開(kāi)啟鏈接,Connection默認(rèn)是關(guān)閉的 Connection connection = connectionFactory.createConnection(); connection.start(); // 第三步:通過(guò)Connection對(duì)象創(chuàng)建Session會(huì)話(上下文環(huán)境對(duì)象),用于接收消息,參數(shù)配置1為是否啟用事務(wù),參數(shù)配置2為簽收模式,一般我們?cè)O(shè)置為自動(dòng)簽收 Session session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE); // 第四步:通過(guò)Session創(chuàng)建Destination對(duì)象,指的是一個(gè)客戶端用來(lái)指定生產(chǎn)消息目標(biāo)和消費(fèi)信息來(lái)源的對(duì)象,在PTP模式中,Destination被稱作Queue即隊(duì)列;在Pub/Sub模式,Destination被稱作Topic即主題。在程序中可以使用多個(gè)Queue和Topic。 Destination destination = session.createQueue("queue1"); // 第五步:我們需要通過(guò)Session對(duì)象創(chuàng)建消息的發(fā)送和接收對(duì)象(生產(chǎn)者和消費(fèi)者)MessageProducer/MessageConsumer。 MessageConsumer messageConsumer = session.createConsumer(destination); while (true) { TextMessage msg = (TextMessage) messageConsumer.receive(); if(msg == null){ break; } System.out.println("接收到的內(nèi)容:" + msg.getText()); } if (connection != null) { connection.close(); } } }
通過(guò)http://localhost:8161/admin/queues.jsp路徑查看消息消費(fèi)情況。
二、ActiveMQ 安全機(jī)制
activeMQ的Web管理界面:http://127.0.0.1:8161/admin
activeMQ管控臺(tái)使用jetty部署,所以需要修改密碼則需要到相應(yīng)的配置文件:apache-activemq-5.14.5\conf\jetty-realm.properties
activeMQ應(yīng)該設(shè)置有安全機(jī)制,只有符合認(rèn)證的用戶才能進(jìn)行發(fā)送和獲取消息,所以我們也可以在activemq.xml里添加安全驗(yàn)證配置,apache-activemq-5.14.5\conf\jetty-realm.properties\activemq.xml,在123行之后添加一個(gè)插件配置即可。
以上這篇ActiveMQ簡(jiǎn)單入門(mén)(新手必看篇)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot使用druid配置多數(shù)據(jù)源問(wèn)題
這篇文章主要介紹了SpringBoot使用druid配置多數(shù)據(jù)源問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03java的poi技術(shù)讀取和導(dǎo)入Excel實(shí)例
本篇文章主要介紹了java的poi技術(shù)讀取和導(dǎo)入Excel實(shí)例,報(bào)表輸出是Java應(yīng)用開(kāi)發(fā)中經(jīng)常涉及的內(nèi)容,有需要的可以了解一下。2016-11-11基于Java中進(jìn)制的轉(zhuǎn)換函數(shù)詳解
下面小編就為大家?guī)?lái)一篇基于Java中進(jìn)制的轉(zhuǎn)換函數(shù)詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07Java實(shí)現(xiàn)對(duì)比兩個(gè)實(shí)體類字段變化的示例詳解
我們?cè)诠ぷ髦?可能會(huì)在日志中記錄數(shù)據(jù)的變化情況或者在公共處理的數(shù)據(jù)增加一個(gè)日志頁(yè)面,我們可以根據(jù)CompareUtils工具類比較數(shù)據(jù)前后發(fā)生了怎樣的變化,下面我們就來(lái)看看具體實(shí)現(xiàn)吧2024-03-03Java數(shù)據(jù)結(jié)構(gòu)之并查集的實(shí)現(xiàn)
并查集是一種用來(lái)管理元素分組情況的數(shù)據(jù)結(jié)構(gòu)。并查集可以高效地進(jìn)行如下操作。本文將通過(guò)Java實(shí)現(xiàn)并查集,感興趣的小伙伴可以了解一下2022-01-01分享Spring Boot 3.x微服務(wù)升級(jí)歷程
Spring Boot 3.0.0 GA版已經(jīng)發(fā)布,好多人也開(kāi)始嘗試升級(jí),有人測(cè)試升級(jí)后,啟動(dòng)速度確實(shí)快了不少,這篇文章主要介紹了Spring Boot 3.x微服務(wù)升級(jí)經(jīng)歷,需要的朋友可以參考下2022-12-12