<code>SpringBoot</code> 是為了簡化 <code>Spring</code> 應用的建立、運作、調試、部署等一系列問題而誕生的産物,自動裝配的特性讓我們可以更好的關注業務本身而不是外部的XML配置,我們隻需遵循規範,引入相關的依賴就可以輕易的搭建出一個 WEB 工程
MQ全稱(Message Queue)又名消息隊列,是一種異步通訊的中間件。可以将它了解成郵局,發送者将消息傳遞到郵局,然後由郵局幫我們發送給具體的消息接收者(消費者),具體發送過程與時間我們無需關心,它也不會幹擾我進行其它事情。常見的MQ有kafka、activemq、zeromq、rabbitmq 等等,各大MQ的對比和優劣勢可以自行Google
RabbitMQ是一個遵循AMQP協定,由面向高并發的<code>erlanng</code>語言開發而成,用在實時的對可靠性要求比較高的消息傳遞上,支援多種語言用戶端。支援<code>延遲隊列(這是一個非常有用的功能)</code>….
Broker:簡單來說就是消息隊列伺服器實體
Exchange:消息交換機,它指定消息按什麼規則,路由到哪個隊列
Queue:消息隊列載體,每個消息都會被投入到一個或多個隊列
Binding:綁定,它的作用就是把<code>exchange</code>和<code>queue</code>按照路由規則綁定起來
Routing Key:路由關鍵字,<code>exchange</code>根據這個關鍵字進行消息投遞
vhost:虛拟主機,一個<code>broker</code>裡可以開設多個<code>vhost</code>,用作不同使用者的權限分離
producer:消息生産者,就是投遞消息的程式
consumer:消息消費者,就是接受消息的程式
channel:消息通道,在用戶端的每個連接配接裡,可建立多個<code>channel</code>,每個<code>channel</code>代表一個會話任務
基于Centos7.x安裝請參考: http://blog.battcn.com/2017/08/20/linux/linux-centos7-ribbitmq/
郵箱發送:使用者注冊後投遞消息到<code>rabbitmq</code>中,由消息的消費方異步的發送郵件,提升系統響應速度
流量削峰:一般在秒殺活動中應用廣泛,秒殺會因為流量過大,導緻應用挂掉,為了解決這個問題,一般在應用前端加入消息隊列。用于控制活動人數,将超過此一定閥值的訂單直接丢棄。緩解短時間的高流量壓垮應用。
訂單逾時:利用<code>rabbitmq</code>的延遲隊列,可以很簡單的實作訂單逾時的功能,比如使用者在下單後30分鐘未支付取消訂單
還有更多應用場景就不一一列舉了…..
在 <code>pom.xml</code> 中添加 <code>spring-boot-starter-amqp</code>的依賴
在 <code>application.properties</code> 檔案中配置<code>rabbitmq</code>相關内容,值得注意的是這裡配置了手動ACK的開關
如果手動建立過或者<code>RabbitMQ</code>中已經存在該隊列那麼也可以省略下述代碼…
建立一個<code>Book</code>類
編寫一個<code>Controller</code>類,用于消息發送工作
預設情況下 <code>spring-boot-data-amqp</code> 是自動<code>ACK</code>機制,就意味着 MQ 會在消息消費完畢後自動幫我們去ACK,這樣依賴就存在這樣一個問題:如果報錯了,消息不會丢失,會無限循環消費,很容易就吧磁盤空間耗完,雖然可以配置消費的次數但這種做法也有失優雅。目前比較推薦的就是我們手動ACK然後将消費錯誤的消息轉移到其它的消息隊列中,做補償處理
完成準備事項後,啟動<code>Chapter11Application</code> 通路 http://localhost:8080/books 将會看到如下内容,就代表一切正常….
目前很多大佬都寫過關于 SpringBoot 的教程了,如有雷同,請多多包涵,本教程基于最新的 <code>spring-boot-starter-parent:2.0.2.RELEASE</code>編寫,包括新版本的特性都會一起介紹…
本文的重點是你有沒有收獲與成長,其餘的都不重要,希望讀者們能謹記這一點。同時我經過多年的收藏目前也算收集到了一套完整的學習資料,包括但不限于:分布式架構、高可擴充、高性能、高并發、Jvm性能調優、Spring,MyBatis,Nginx源碼分析,Redis,ActiveMQ、Mycat、Netty、Kafka、Mysql、Zookeeper、Tomcat、Docker、Dubbo、Nginx等多個知識點進階進階幹貨,希望對想成為架構師的朋友有一定的參考和幫助