SpringBoot對異步消息(MQ)的支持

1.異步消息的定義

??異步消息的主要目的是為了系統(tǒng)與系統(tǒng)之間的通信,所謂異步消息即消息發(fā)送者無需等待消息接收者的處理以及返回,甚至無需關心消息是否發(fā)送成功
??在異步消息中有兩個很重要的概念,即消息代理和目的地,當消息發(fā)送者發(fā)送消息之后,消息將由消息代理接管,消息代理保證消息傳遞到指定目的地。
??異步消息主要有兩種目的地形式,隊列(queue)和主題(topic),隊列用于點對點形式的消息通信,主題用于發(fā)布訂閱式的消息通信。

1.1目的地形式分類

1.1.1點對點式

??當消息發(fā)送者發(fā)送消息,消息代理將消息后將消息放進一個隊列里,當有消息接收者來接收消息的時候,消息將從隊列中取出傳遞給消息接收者,這時候隊列里就沒有了這條消息。點對點式確保每一條消息只有唯一的發(fā)送者和接收者,但這并不能說明只有一個接收者能夠從隊列中接收消息,因為隊列中有多個消息,點對點式只保證每一條消息只有唯一的發(fā)送者和接收者

1.1.2發(fā)布/訂閱式

??發(fā)布訂閱式是消息發(fā)送者發(fā)送消息到主題,而多個消息接收者監(jiān)聽這個主題,此時的消息發(fā)送者和接收者分別叫做發(fā)布者和訂閱者

1.2 企業(yè)級消息代理

??JMS即JAVA消息服務,是基于JVM的消息代理規(guī)范,ActiveMQ是一個JMS的實現(xiàn)
AMQP也是一個消息代理的規(guī)范,他不僅兼容JMS,還支持跨語言和平臺,AMQP的主要實現(xiàn)是RabbitMQ

1.3 Spring以及SpringBoot的支持

??Spring針對JMS和RabbitMQ分別提供了JmsTemplete和RabbitTemplete來發(fā)送消息。為我們提供了@JmsListener,@RabbitListener注解來監(jiān)聽消息代理發(fā)送的消息。我們分別需要通過@EnableJms和@EnableRabbit來開啟支持
??SpringBoot自動配置了上述@EnableJms,@EnableRabbit,JmsTemplete,RabbitTemplete的支持,同時我們可以在application.properties文件中分別以spring.activemq和spring.rabbitmq來分別配置所需的屬性。

2.SpringBoot對JMS(ActiveMQ)的支持

下載安裝

ActiveMQ的官方下載地址:http://activemq.apache.org/download.html,下載安裝完成后
進入bin目錄,發(fā)現(xiàn)有win32和win64兩個文件夾,這2個文件夾分別對應windows32位和windows64位操作系統(tǒng)的啟動腳本。進入對應的文件夾中雙擊activemq.bat。即可正常啟動
訪問http://localhost:8161/admin。輸入默認的用戶名和密碼:admin/admin即可進入ActiveMQ的控制臺

2.2 配置

SpringBoot提供了針對ActiveMQ的支持,只需要在pom.xml文件中引入即可:

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-activemq</artifactId>
        </dependency>

在application.properties配置ActiveMQ的消息代理地址:

spring.activemq.broker-url=tcp://localhost:61616

注意,此處配置的消息代理必須讓ActiveMQ啟動時才有作用,否則無效

在實際情況下,消息的發(fā)布者和接受者一般都是分開的,而這里,我們僅作測試,將消息發(fā)送者和接收者放在一個程序中

2.3代碼文件

2.3.1消息定義

public class Msg implements MessageCreator {
    @Override
    public Message createMessage(Session session) throws JMSException {
        return session.createTextMessage("測試消息");
    }
}

2.3.2消息發(fā)送及目的地定義

@SpringBootApplication
public class SpringBootMqApplication implements CommandLineRunner{

    @Autowired
    JmsTemplate  jmsTemplate;
    public static void main(String[] args) {
        SpringApplication.run(SpringBootMqApplication.class, args);
    }

    @Override
    public void run(String... args) throws Exception {
            jmsTemplate.send("my-destination",new Msg());
    }
}

CommandLineRunner接口中的run方法,是在程序啟動后就會執(zhí)行的代碼。JmsTemplate 是用來操作JMS消息的操作類。

2.3.3消息監(jiān)聽

@Component
public class Receiver {
    @JmsListener(destination = "my-destination")
    public void  receivedMessage(String message){
        System.out.println("接受到"+message);
    }
}

@JmsListener顯示的定義了指定要監(jiān)聽的目的地。

2.3.4運行結果

運行結果顯示監(jiān)聽收到了消息


這里寫圖片描述

ActiveMQ的控制臺中顯示我們發(fā)送的消息


這里寫圖片描述

3.SpringBoot對AMQP(RabbitMQ)的支持

3.1RabbitMQ的安裝配置

??RabbitMQ是基于Erlang語言開發(fā)的。所以安裝RabbitMQ之前需要先下載安裝配置Erlang,下載地址:http://www.erlang.org/downloads
并將安裝后的D:\Program Files\erl9.0\bin的bin目錄配置到path環(huán)境變量中。然后下載安裝RabbitMQ。下載地址:http://www.rabbitmq.com/download.html
安裝完成之后在開始菜單中找到RabbitMQ Command Promt,打開控制臺,輸入命令

rabbitmq-plugins enable rabbitmq_management

控制臺無錯誤之后,訪問http://localhost:15672。使用默認的用戶名/密碼:guest/guest進行登錄
即可見到如圖所示界面:

這里寫圖片描述

3.2 RabbitMQ測試代碼文件

SpringBoot默認Rabbit的主機為localhost,端口號為5672,所以我們無需為RabbitMQ配置其他信息。
入口文件

import org.springframework.amqp.core.Queue;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;

import java.lang.annotation.Annotation;

@SpringBootApplication
public class SpringBootAmqpApplication implements CommandLineRunner {
    @Autowired
     RabbitTemplate rabbitTemplate;
    public static void main(String[] args) {
        SpringApplication.run(SpringBootAmqpApplication.class, args);
    }

    @Bean //2
    public Queue wiselyQueue(){
        return new Queue("my-queue");
    }

    @Override
    public void run(String... strings) throws Exception {
        rabbitTemplate.convertAndSend("my-queue","來自RabbitMQ的問候");
    }
}

接收類

@Component
public class Receiver {
    @RabbitListener(queues = "my-queue")
    public  void  ReceiveMesaage(String  message){
        System.out.println("接受到"+message);
    }
}

3.3 測試結果

這里寫圖片描述

在RabbitMQ控制臺中額可以看到


這里寫圖片描述

4 小結

??這里主要是對ActiveMQ和RabbitMQ進行了簡單的嘗試,了解了異步消息的通信。有興趣的同學可以進行深入研究。

代碼文件
參考書籍:JavaEE開發(fā)的顛覆者--SpringBoot實戰(zhàn)

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,001評論 6 537
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,786評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 176,986評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,204評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,964評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,354評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,410評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,554評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 49,106評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,918評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,093評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,648評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,342評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,755評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,009評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,839評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,107評論 2 375

推薦閱讀更多精彩內容