您好,登錄后才能下訂單哦!
今天小編給大家分享一下docker安裝RabbitMQ及安裝延遲插件的方法的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
我這個安裝攻略首先得保證服務器上安裝過docker了 如果沒安裝docker請先去安裝docker
MQ(message queue)字面意思上來說消息隊列,FIFO先入先出,隊列中存入的內容是message,是一種跨進程的通信機制,用于上下游傳遞消息。MQ 是一種非常常見的上下游“邏輯解耦+物理解耦”的消息通信服務。使用了 MQ 之后,消息發送上游只需要依賴 MQ,不用依賴其他服務。
比如說訂單系統最多一次可以處理一萬次訂單,這個處理能力在正常時段下單時綽綽有余,但是在高峰期時如果有兩萬次下單操作系統是處理不了的只能限制訂單超過一萬次后不允許用戶下單,但是如果使用消息隊列做緩沖,我們可以取消這個限制,把一米內的訂單分散成一段時間來處理,這個時候有些用戶可能在下單十幾秒后才能收到下單成功消息 但是這樣總比不能讓用戶下單體驗好
以電商應用為例,應用中有訂單系統、庫存系統、物流系統、支付系統。用戶創建訂單后,如果耦合調用庫存系統、物流系統、支付系統,任何一個子系統出了故障,都會造成下單操作異常。當轉變成基于消息隊列的方式后,系統間調用的問題會減少很多,比如物流系統因為發生故障,需要幾分鐘來修復。在這幾分鐘的時間里,物流系統要處理的內存被緩存在消息隊列中,用戶的下單操作可以正常完成。當物流系統恢復后,繼續處理訂單信息即可,中單用戶感受不到物流系統的故障,提升系統的可用性
有些服務間調用是異步的,例如 A 調用 B,B 需要花費很長時間執行,但是 A 需要知道 B 什么時候可以執行完,一般有兩種方式,A 過一段時間去調用 B 的查詢 api 查詢。或者 A 提供一個 callbackB 執行完之后調用 api 通知 A 服務。這兩種方式都不是很優雅,使用消息總線,可以很方便解決這個問題,A 調用 B 服務后,只需要監聽 B 處理完成的消息,當 B 處理完成后,會發送一條消息給 MQ,MQ 會將此消息轉發給 A 服務。這樣 A 服務既不用循環調用 B 的查詢 api,也不用提供 callback同樣 B 服務也不用做這些操作。A 服務還能及時的得到異步處理成功的消息。
接下來使用docker進行RabbitMQ的安裝
直接拉取鏡像的話默認拉取最新的版本
docker pull rabbitmq:management
注意修改用戶名和密碼
docker run -d -p 15672:15672 -p 5672:5672 \ -e RABBITMQ_DEFAULT_VHOST=my_vhost \ -e RABBITMQ_DEFAULT_USER=admin \ -e RABBITMQ_DEFAULT_PASS=admin \ --hostname myRabbit \ --name rabbitmq \ rabbitmq
參數說明:
-d:表示在后臺運行容器;
-p:將容器的端口 5672(應用訪問端口)和 15672 (控制臺Web端口號)映射到主機中;
-e:指定環境變量:
RABBITMQ_DEFAULT_VHOST:默認虛擬機名;
RABBITMQ_DEFAULT_USER:默認的用戶名;
RABBITMQ_DEFAULT_PASS:默認的用戶密碼;
--hostname:指定主機名(RabbitMQ 的一個重要注意事項是它根據所謂的 節點名稱 存儲數據,默認為主機名);
--name rabbitmq:設置容器名稱;
rabbitmq:容器使用的鏡像名稱;
啟動完成后可以通過 docker ps 命令來查看容器是否啟動
還可以設置docker啟動時自動啟動
docker update rabbitmq --restart=always
//進入容器內部 我這里使用容器名字進入 也可以使用容器id docker exec -it rabbitmq /bin/bash ---------------------------------- //開啟web后臺管理界面 rabbitmq-plugins enable rabbitmq_management
瀏覽器輸入地址 hhtp://ip:15672 即可訪問后臺管理界面 這里的ip為運行RabbitMQ的服務器ip
默認的用戶名和密碼都是guest
但由于我們啟動的時候設置了默認的用戶名和密碼,所以我們可以使用設置的用戶名和密碼登錄。
如果無法訪問 可以嘗試打開防火墻 如果是在阿里或者騰訊之類的服務器 要打開安全組的端口!!
到這里 我們docker安裝RabbitMQ就完成了 接下來進行延遲插件的安裝
下載地址 https://www.rabbitmq.com/community-plugins.html
進入web端后左上角有顯示當前安裝的RabbitMQ版本
我這里安裝的是3.10版本所以我直接下載最新版的插件就可以
將剛剛上傳的插件拷貝到容器內plugins目錄下
docker cp /root/rabbitmq_delayed_message_exchange-3.10.2.ez rabbitmq:/plugins
上傳之后進入容器內部
//進入容器 我這里使用容器名字 也可以用容器id進入 docker exec -it rabbitmq /bin/bash ------------------------------------- //移動到plugins目錄下 cd plugins ------------------------------------- //查看是否上傳成功 ls
然后我們啟動插件
rabbitmq-plugins enable rabbitmq_delayed_message_exchange
安裝成功后 退出容器
exit
然后重啟容器
//我這里還是使用容器名稱 也可以使用容器id docker restart rabbitmq
容器啟動成功之后,登錄RabbitMQ的管理界面(ip:15672 訪問web界面),找到ExchangesTab頁。點擊Add a new exchange,在Type里面查看是否有x-delayed-message選項,如果存在就代表插件安裝成功。
以上就是“docker安裝RabbitMQ及安裝延遲插件的方法”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。