亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Docker搭建RabbitMQ集群的方法步驟

 更新時間:2022年01月17日 09:07:24   作者:萬里顧—程  
本文主要介紹了Docker搭建RabbitMQ集群的方法步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

集群模式介紹

RabbitMQ集群模式有兩種:普通模式和鏡像模式

  • 普通模式:默認(rèn)模式,多個節(jié)點組成的普通集群,消息隨機(jī)發(fā)送到其中一個節(jié)點的隊列上,其他節(jié)點僅保留元數(shù)據(jù),各個節(jié)點僅有相同的元數(shù)據(jù),即隊列結(jié)構(gòu)、交換器結(jié)構(gòu)、交換器與隊列綁定關(guān)系、vhost。消費者消費消息時,會從各個節(jié)點拉取消息,如果保存消息的節(jié)點故障,則無法消費消息,如果做了消息持久化,那么得等該節(jié)點恢復(fù),然后才可被消費;如果沒有持久化的話,就會產(chǎn)生消息丟失的現(xiàn)象。
  • 鏡像模式:它是在普通模式的基礎(chǔ)上,把需要的隊列做成鏡像隊列,存在于多個節(jié)點來實現(xiàn)高可用(HA)。該模式解決了上述問題,Broker會主動地將消息實體在各鏡像節(jié)點間同步,在consumer取數(shù)據(jù)時無需臨時拉取。該模式帶來的副作用也很明顯,除了降低系統(tǒng)性能外,如果鏡像隊列數(shù)量過多,加之大量的消息進(jìn)入,集群內(nèi)部的網(wǎng)絡(luò)帶寬將會被大量消耗。通常地,對可靠性要求較高的場景建議采用鏡像模式。

1、普通集群的搭建

1.1、普通集群架構(gòu)介紹

架構(gòu)圖

在這里插入圖片描述

1.2、環(huán)境準(zhǔn)備

拉取RabbitMQ鏡像

docker pull rabbitmq:3.7-management

在這里插入圖片描述

創(chuàng)建并運行三個RabbitMQ容器節(jié)點,一主兩從

命令如下:

#rabbitmqCluster01 主節(jié)點
docker run -d --hostname rabbitmq01 --name rabbitmqCluster01 -v `pwd`/rabbitmq01:/var/lib/rabbitmq -p 15672:15672 -p 5672:5672 -e RABBITMQ_ERLANG_COOKIE='rabbitmqCookie' rabbitmq:3.7-management

#rabbitmqCluster02 從節(jié)點
docker run -d --hostname rabbitmq02 --name rabbitmqCluster02 -v `pwd`/rabbitmq02:/var/lib/rabbitmq -p 7002:15672 -p 5673:5672 -e RABBITMQ_ERLANG_COOKIE='rabbitmqCookie'  --link rabbitmqCluster01:rabbitmq01 rabbitmq:3.7-management

#rabbitmqCluster03 從節(jié)點
docker run -d --hostname rabbitmq03 --name rabbitmqCluster03 -v `pwd`/rabbitmq03:/var/lib/rabbitmq -p 8002:15672 -p 5674:5672 -e RABBITMQ_ERLANG_COOKIE='rabbitmqCookie'  --link rabbitmqCluster01:rabbitmq01 --link rabbitmqCluster02:rabbitmq02  rabbitmq:3.7-management

-d 后臺運行容器;

–name 指定容器名;

-p 指定服務(wù)運行的端口(5672:應(yīng)用訪問端口;15672:控制臺Web端口號),控制臺端口用于管理rabbitmq,應(yīng)用訪問端口號為rabbitclient等應(yīng)用訪問。;

-v 映射目錄或文件,pwd 當(dāng)前目錄;

–hostname 主機(jī)名(RabbitMQ的一個重要注意事項是它根據(jù)所謂的 “節(jié)點名稱” 存儲數(shù)據(jù),默認(rèn)為主機(jī)名);

-e 指定環(huán)境變量;(RABBITMQ_DEFAULT_VHOST:默認(rèn)虛擬機(jī)名;RABBITMQ_DEFAULT_USER:默認(rèn)的用戶名;RABBITMQ_DEFAULT_PASS:默認(rèn)用戶名的密碼,RABBITMQ_ERLANG_COOKIE 節(jié)點認(rèn)證作用,部署集成時 需要同步該值)

–link 用于容器的鏈接

查看運行中的三個RabbitMQ容器:

在這里插入圖片描述

登錄 RabbitMQ 控制臺界面:

rabbitmq01 節(jié)點:

在這里插入圖片描述

rabbitmq02 節(jié)點:

在這里插入圖片描述

rrabbitmq03 節(jié)點

在這里插入圖片描述

1.3、集群搭建

將rabbitmqCluster02 節(jié)點和 rabbitmqCluster03 節(jié)點加入 rabbitmqCluster01 創(chuàng)建集群

進(jìn)入 rabbitmqCluster02 節(jié)點和 rabbitmqCluster03 節(jié)點,在兩個節(jié)點分別執(zhí)行一下加入集群的命令:

rabbitmqctl stop_app

rabbitmqctl reset
#rabbitmq01為rabbitmqCluster01容器中的hostname
rabbitmqctl join_cluster --ram rabbit@rabbitmq01

rabbitmqctl start_app

rabbitmqCluster02 節(jié)點:

在這里插入圖片描述

rabbitmq-slave1 節(jié)點:

在這里插入圖片描述

執(zhí)行完后在任意節(jié)點查看集群狀態(tài):

rabbitmqctl cluster_status

如果出現(xiàn)如下顯示,集群搭建成功:

在這里插入圖片描述

之后我們在主節(jié)點的web管理頁可以看到兩個從節(jié)點了:

在這里插入圖片描述

2、鏡像集群的搭建

鏡像集群的結(jié)構(gòu)圖

在這里插入圖片描述

2.1、配置鏡像集群的策略

1、使用命令配置策略:

rabbitmqctl set_policy [-p Vhost] [--priority <priority>] [--apply-to <apply-to>] Name Pattern Definition

參數(shù)說明:

-p Vhost: 可選參數(shù),針對指定 vhost 下的 queue 進(jìn)行設(shè)置

Name: policy 的名稱

Pattern: queue 的匹配模式(正則表達(dá)式)

Definition:鏡像定義,包括三個部分 ha-mode, ha-params, ha-sync-mode

ha-mode:指明鏡像隊列的模式,有效值為 all/exactly/nodes

all:表示在集群中所有的節(jié)點上進(jìn)行鏡像

exactly:表示在指定個數(shù)的節(jié)點上進(jìn)行鏡像,節(jié)點的個數(shù)由 ha-params 指定

nodes:表示在指定的節(jié)點上進(jìn)行鏡像,節(jié)點名稱通過 ha-params 指定

ha-params:作為參數(shù),為 ha-mode 的補(bǔ)充

ha-sync-mode:進(jìn)行隊列中消息的同步方式,有效值為 automatic 和 manual

pririty:可選參數(shù),policy的優(yōu)先級

在任意節(jié)點上添加策略:

#^hello 匹配hello開頭的隊列
rabbitmqctl set_policy ha-all "^hello" '{"ha-mode":"all","ha-sync-mode":"automatic"}'

在所有節(jié)點的以hello開頭的隊列上都添加了策略:以后當(dāng)主節(jié)點宕機(jī)時,hello隊列里未消費的消息也不會丟失,會復(fù)制到其他節(jié)點上。

在這里插入圖片描述

刪除策略:

#rabbitmqctl clear_policy 策略名稱
rabbitmqctl clear_policy ha-all

2、管理界面配置策略

登錄 rabbitmq 管理頁面 ——> Admin ——> Policies ——> Add / update a policy

在這里插入圖片描述

name:策略名稱

Pattern:^匹配符,只有一個^代表匹配所有。^message指同步“message”開頭的隊列名稱

Definition:ha-mode=all 為匹配類型,分為3種模式:all(表示所有的queue)

Priority:優(yōu)先級,首先根據(jù)priority排序,值越大的優(yōu)先級越高;相同priority則根據(jù)創(chuàng)建時間排序,越晚創(chuàng)建的優(yōu)先級越高。

Operator Policy 和 User Policy 的區(qū)別:

  • Operator Policy 是給服務(wù)提供商或公司基礎(chǔ)設(shè)施部門用來設(shè)置某些需要強(qiáng)制執(zhí)行的通用規(guī)則
  • User Policy 是給業(yè)務(wù)應(yīng)用用來設(shè)置的規(guī)則

到此這篇關(guān)于Docker搭建RabbitMQ集群的方法步驟的文章就介紹到這了,更多相關(guān)Docker搭建RabbitMQ集群內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Linux服務(wù)器安裝Docker,啟動失敗問題的解決

    Linux服務(wù)器安裝Docker,啟動失敗問題的解決

    這篇文章主要介紹了Linux服務(wù)器安裝Docker,啟動失敗問題的解決方案,具有很好的參考價值,希望對大家有所幫助。
    2023-04-04
  • docker容器非root用戶提權(quán)的問題解決

    docker容器非root用戶提權(quán)的問題解決

    本文主要介紹了docker容器非root用戶提權(quán)的問題解決,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 使用Docker的NFS-Ganesha鏡像搭建nfs服務(wù)器的詳細(xì)過程

    使用Docker的NFS-Ganesha鏡像搭建nfs服務(wù)器的詳細(xì)過程

    這篇文章主要介紹了使用Docker的NFS-Ganesha鏡像搭建nfs服務(wù)器,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • Docker使用Dockerfile來創(chuàng)建鏡像

    Docker使用Dockerfile來創(chuàng)建鏡像

    本篇文章主要介紹了Docker使用Dockerfile來創(chuàng)建鏡像,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • Docker安裝和基礎(chǔ)用法 Docker入門教程第二篇

    Docker安裝和基礎(chǔ)用法 Docker入門教程第二篇

    這篇文章主要介紹了Docker安裝和基礎(chǔ)用法,Docker入門教程第二篇,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • docker啟動elasticsearch時內(nèi)存不足問題及解決方法

    docker啟動elasticsearch時內(nèi)存不足問題及解決方法

    這篇文章主要介紹了docker啟動elasticsearch時內(nèi)存不足問題,本文給大家分享安裝過程及解決方法,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • 使用docker-compose.yml構(gòu)建鏡像的方法

    使用docker-compose.yml構(gòu)建鏡像的方法

    docker-compose是docker提供的一個命令行工具,用來定義和運行由多個容器組成的應(yīng)用,這篇文章主要介紹了使用docker-compose.yml構(gòu)建鏡像的方法,需要的朋友可以參考下
    2023-05-05
  • Ubuntu Docker 源碼編譯(1.9.1 )詳解

    Ubuntu Docker 源碼編譯(1.9.1 )詳解

    這篇文章主要介紹了Ubuntu Docker 源碼編譯(1.9.1 )詳解的相關(guān)資料,這里對編譯過程進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以參考下
    2016-11-11
  • 詳解如何修改 Docker 默認(rèn)網(wǎng)橋地址

    詳解如何修改 Docker 默認(rèn)網(wǎng)橋地址

    這篇文章主要介紹了詳解如何修改 Docker 默認(rèn)網(wǎng)橋地址,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • win10家庭版安裝Docker的方法步驟

    win10家庭版安裝Docker的方法步驟

    這篇文章主要介紹了win10家庭版安裝Docker的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09

最新評論