中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

docker安裝RabbitMQ及安裝延遲插件的方法

發布時間:2022-06-06 09:26:53 來源:億速云 閱讀:179 作者:zzz 欄目:開發技術

今天小編給大家分享一下docker安裝RabbitMQ及安裝延遲插件的方法的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

    我這個安裝攻略首先得保證服務器上安裝過docker了 如果沒安裝docker請先去安裝docker

    1.首先說一下什么是MQ

    MQ(message queue)字面意思上來說消息隊列,FIFO先入先出,隊列中存入的內容是message,是一種跨進程的通信機制,用于上下游傳遞消息。MQ 是一種非常常見的上下游“邏輯解耦+物理解耦”的消息通信服務。使用了 MQ 之后,消息發送上游只需要依賴 MQ,不用依賴其他服務。

    1.1為什么要用MQ/MQ有什么用

    1.1.1流量消峰

    比如說訂單系統最多一次可以處理一萬次訂單,這個處理能力在正常時段下單時綽綽有余,但是在高峰期時如果有兩萬次下單操作系統是處理不了的只能限制訂單超過一萬次后不允許用戶下單,但是如果使用消息隊列做緩沖,我們可以取消這個限制,把一米內的訂單分散成一段時間來處理,這個時候有些用戶可能在下單十幾秒后才能收到下單成功消息 但是這樣總比不能讓用戶下單體驗好

    1.1.2應用解耦

    以電商應用為例,應用中有訂單系統、庫存系統、物流系統、支付系統。用戶創建訂單后,如果耦合調用庫存系統、物流系統、支付系統,任何一個子系統出了故障,都會造成下單操作異常。當轉變成基于消息隊列的方式后,系統間調用的問題會減少很多,比如物流系統因為發生故障,需要幾分鐘來修復。在這幾分鐘的時間里,物流系統要處理的內存被緩存在消息隊列中,用戶的下單操作可以正常完成。當物流系統恢復后,繼續處理訂單信息即可,中單用戶感受不到物流系統的故障,提升系統的可用性

    docker安裝RabbitMQ及安裝延遲插件的方法

    1.1.3異步處理

    有些服務間調用是異步的,例如 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 服務還能及時的得到異步處理成功的消息。

    2.安裝RabbitMq

    接下來使用docker進行RabbitMQ的安裝

    2.1首先拉取鏡像

    直接拉取鏡像的話默認拉取最新的版本

    docker pull rabbitmq:management

    2.2啟動鏡像

    注意修改用戶名和密碼

    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

    2.3啟動 rabbitmq_management (RabbitMQ后臺管理)

    //進入容器內部  我這里使用容器名字進入 也可以使用容器id
    docker exec -it rabbitmq /bin/bash
    ----------------------------------
    //開啟web后臺管理界面
    rabbitmq-plugins enable rabbitmq_management
    2.3.1打開RabbitMQweb界面
    1. 瀏覽器輸入地址 hhtp://ip:15672 即可訪問后臺管理界面 這里的ip為運行RabbitMQ的服務器ip

    2. 默認的用戶名和密碼都是guest

    3. 但由于我們啟動的時候設置了默認的用戶名和密碼,所以我們可以使用設置的用戶名和密碼登錄。

    docker安裝RabbitMQ及安裝延遲插件的方法

    如果無法訪問 可以嘗試打開防火墻 如果是在阿里或者騰訊之類的服務器 要打開安全組的端口!!
    到這里 我們docker安裝RabbitMQ就完成了 接下來進行延遲插件的安裝

    3.插件下載并安裝

    下載地址 https://www.rabbitmq.com/community-plugins.html

    docker安裝RabbitMQ及安裝延遲插件的方法

    docker安裝RabbitMQ及安裝延遲插件的方法

    進入web端后左上角有顯示當前安裝的RabbitMQ版本

    docker安裝RabbitMQ及安裝延遲插件的方法

    我這里安裝的是3.10版本所以我直接下載最新版的插件就可以

    docker安裝RabbitMQ及安裝延遲插件的方法

    安裝完成后用工具將插件文件上傳到服務器上

    將剛剛上傳的插件拷貝到容器內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

    docker安裝RabbitMQ及安裝延遲插件的方法

    然后我們啟動插件

    rabbitmq-plugins enable rabbitmq_delayed_message_exchange

    docker安裝RabbitMQ及安裝延遲插件的方法

    安裝成功后 退出容器

    exit

    然后重啟容器

    //我這里還是使用容器名稱 也可以使用容器id
    docker restart rabbitmq

    容器啟動成功之后,登錄RabbitMQ的管理界面(ip:15672 訪問web界面),找到ExchangesTab頁。點擊Add a new exchange,在Type里面查看是否有x-delayed-message選項,如果存在就代表插件安裝成功。

    docker安裝RabbitMQ及安裝延遲插件的方法

    以上就是“docker安裝RabbitMQ及安裝延遲插件的方法”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    喀喇| 新竹市| 南宁市| 界首市| 广宁县| 泗洪县| 饶阳县| 皋兰县| 贺兰县| 丽江市| 无锡市| 高要市| 天水市| 四平市| 隆回县| 长武县| 青龙| 黄浦区| 衡东县| 红原县| 库尔勒市| 柳林县| 枞阳县| 慈利县| 珲春市| 揭阳市| 湘潭县| 罗田县| 湖州市| 三河市| 平塘县| 凤阳县| 新和县| 宁阳县| 锡林浩特市| 永定县| 威远县| 浙江省| 石嘴山市| 洞头县| 田东县|