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

溫馨提示×

溫馨提示×

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

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

Centos7 RabbitMQ消息隊列集群

發布時間:2020-07-22 11:24:31 來源:網絡 閱讀:677 作者:蔣將將 欄目:建站服務器

一、簡介

      MQ(Message Queue,消息隊列)是一款消息中間件,一般以集群方式部署,主要提供消息的接受和發送,實現各微服務之間的消息異步。

1、集群原理

      rabbitmq 是依據erlang的分布式特性(RabbitMQ底層是通過Erlang架構來實現的,所以rabbitmqctl會啟動Erlang節點,并基于Erlang節點來使用Erlang系統連接RabbitMQ節點,在連接過程中需要正確的Erlang Cookie和節點名稱,Erlang節點通過交換Erlang Cookie以獲得認證)來實現的,所以部署rabbitmq分布式集群時要先安裝erlang,并把其中一個服務的cookie復制到另外的節點。

      rabbitmq集群中,各個rabbitmq為對等節點,即每個節點均提供給客戶端連接,進行消息的接收和發送。節點分為內存節點和磁盤節點,一般的,均應建立為磁盤節點,為了防止機器重啟后的消息消失;

      RabbitMQ的Cluster集群模式一般分為兩種, 普通模式和鏡像模式 。消息隊列通過rabbitmq HA鏡像隊列進行消息隊列實體復制。

      普通模式下, 以兩個節點(rabbit01、rabbit02)為例來進行說明。對于Queue來說,消息實體只存在于其中一個節點rabbit01(或者rabbit02),rabbit01和rabbit02兩個節點僅有相同的元數據,即隊列的結構。當消息進入rabbit01節點的Queue后,consumer從rabbit02節點消費時,RabbitMQ會臨時在rabbit01、rabbit02間進行消息傳輸,把A中的消息實體取出并經過B發送給consumer。所以consumer應盡量連接每一個節點,從中取消息。即對于同一個邏輯隊列,要在多個節點建立物理Queue。否則無論consumer連rabbit01或rabbit02,出口總在rabbit01,會產生瓶頸。

      鏡像模式下, 將需要消費的隊列變為鏡像隊列,存在于多個節點,這樣就可以實現RabbitMQ的HA高可用性。作用就是消息實體會主動在鏡像節點之間實現同步,而不是像普通模式那樣,在consumer消費數據時臨時讀取。缺點就是,集群內部的同步通訊會占用大量的網絡帶寬。

2、系統架構

Centos7 RabbitMQ消息隊列集群Centos7 RabbitMQ消息隊列集群

概念說明:

Broker:它提供一種傳輸服務,它的角色就是維護一條從生產者到消費者的路線,保證數據能按照指定的方式進行傳輸

Exchange:消息交換機,它指定消息按什么規則,路由到哪個隊列

Queue:消息的載體,每個消息都會被投到一個或多個隊列

Binding:綁定,它的作用就是把exchange和queue按照路由規則綁定起來

Routing Key:路由關鍵字,exchange根據這個關鍵字進行消息投遞

vhost:虛擬主機,一個broker里可以有多個vhost,用作不同用戶的權限分離

Producer:消息生產者,就是投遞消息的程序

Consumer:消息消費者,就是接受消息的程序

Channel:消息通道,在客戶端的每個連接里,可建立多個channel

二、環境準備

1、系統環境

主機名

系統

IP

用途

master

CentOS7.4

192.168.56.129

磁盤節點

slave1

CentOS7.4

192.168.56.130

內存節點

slave2

CentOS7.4

192.168.56.131

內存節點

2、暫時關閉防火墻和selinux

3、設置三個節點主機名hosts

[root@master ~]# cat /etc/hosts

192.168.56.129 master

192.168.56.130 slave1

192.168.56.131 slave2

三、搭建服務

1、安裝最新repo源

[root@master ~]# yum -y install epel-release

2、安裝三個節點的rabbitmq-server軟件包

[root@master ~]# yum -y install rabbitmq-server

Centos7 RabbitMQ消息隊列集群Centos7 RabbitMQ消息隊列集群

3、查看已安裝的插件

[root@master ~]# rabbitmq-plugins list

Centos7 RabbitMQ消息隊列集群Centos7 RabbitMQ消息隊列集群

4、啟動管理服務(三個節點)

[root@master ~]# rabbitmq-plugins enable rabbitmq_management

Centos7 RabbitMQ消息隊列集群Centos7 RabbitMQ消息隊列集群

5、分別啟動rabbitmq服務(三個節點)

[root@master ~]# systemctl start rabbitmq-server.service

rabbitmq集群部署

1、關閉服務(三個節點)

[root@master ~]# systemctl stop rabbitmq-server.service

2、進入cookie文件目錄,配置(各節點需要有相同序列號值)

[root@master ~]# cd /var/lib/rabbitmq/

[root@master rabbitmq]# vim .erlang.cookie

Centos7 RabbitMQ消息隊列集群Centos7 RabbitMQ消息隊列集群

3、再啟動rabbitmq服務

[root@master rabbitmq]# systemctl start rabbitmq-server.service

4、關閉rabbitmq應用(只關閉slave1和slave2)

[root@master rabbitmq]# rabbitmqctl stop_app

Centos7 RabbitMQ消息隊列集群Centos7 RabbitMQ消息隊列集群

5、將slave1、slave2加入master,使它們成為一個集群。再次啟動應用

[root@slave1 ~]# rabbitmqctl join_cluster --ram rabbit@master

[root@slave1 ~]# rabbitmqctl start_app

Centos7 RabbitMQ消息隊列集群

Centos7 RabbitMQ消息隊列集群

Centos7 RabbitMQ消息隊列集群Centos7 RabbitMQ消息隊列集群6、分別查看rabbitmq服務器狀態

[root@master ~]# rabbitmqctl cluster_status

Centos7 RabbitMQ消息隊列集群

Centos7 RabbitMQ消息隊列集群

Centos7 RabbitMQ消息隊列集群7、通過客戶端瀏覽器進行訪問RabbitMQ (用戶名:guest 密碼:guest)

http://192.168.56.129:15672

Centos7 RabbitMQ消息隊列集群

Centos7 RabbitMQ消息隊列集群

向AI問一下細節

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

AI

顺昌县| 灵台县| 墨竹工卡县| 邵东县| 大英县| 咸宁市| 营口市| 南开区| 德保县| 资溪县| 荔浦县| 金平| 伊金霍洛旗| 湟源县| 隆尧县| 宜黄县| 商城县| 清水县| 凯里市| 治多县| 渭南市| 田阳县| 成都市| 武陟县| 孝感市| 北安市| 宽甸| 松桃| 远安县| 家居| 东安县| 抚州市| 辽源市| 龙陵县| 寻乌县| 历史| 桐庐县| 巫溪县| 太仆寺旗| 峨眉山市| 钦州市|