我們一起來(lái)學(xué)RabbitMQ 四,RabbitMQ windows 安裝

RabbitMQ windows 安裝

下載 RabbitMQ

https://www.rabbitmq.com/install-windows.html

搜索關(guān)鍵字 Download

image

下載 erlang 環(huán)境安裝包下

https://www.erlang.org/downloads

image

安裝配置erlang

點(diǎn)擊上述下載的 otp_win64_24.0.exe

一直 next 即可,記住自己的安裝路徑,使用默認(rèn)的即可,若自定義,最好全路徑都是英文

新建環(huán)境變量

  • 新建系統(tǒng)變量 - 鍵入變量名 ERLANG_HOME
image
  • %ERLANG_HOME%\bin 添加到 Path 路徑下
image
  • 進(jìn)入 cmd 查看效果
image-

如上圖效果,即為安裝配置 erlang 環(huán)境成功

安裝配置 RabbitMQ server

image

會(huì)看到上述效果,三個(gè)插件被啟動(dòng)了

賬號(hào):guest

密碼:guest

image

命令(cmd 中可以執(zhí)行)

net start RabbitMQ  啟動(dòng)
net stop RabbitMQ  停止
rabbitmqctl status  查看狀態(tài)

RabbitMQ ubuntu 安裝

咱們?cè)賮?lái)看看linux 中RabbitMQ 如何安裝和使用

RabbitMQ使用erlang語(yǔ)言寫的,所以在安裝RabbitMQ前,我們需要安裝erlang,erlang又需要安裝 python 和 simplejson

安裝 pyhton

wget https://www.python.org/ftp/python/3.5.2/Python-3.5.2.tar.xz

tar xvf  Python-3.5.2.tar.xz

cd Python-3.5.2

./configure

make && make install

安裝 simplejson

sudo apt-get install python-simplejson -y

安裝 Erlang依賴包

sudo apt-get install build-essential -y
sudo apt-get install libncurses5-dev -y
sudo apt-get install libssl-dev -y
sudo apt-get install m4 -y
sudo apt-get install unixodbc unixodbc-dev -y
sudo apt-get install freeglut3-dev libwxgtk2.8-dev -y
sudo apt-get install xsltproc -y
sudo apt-get install fop -y
sudo apt-get install tk8  -y

安裝 Erlang

sudo apt-get install erlang -y

安裝 RabbitMQ

sudo apt-get update

sudo apt-get install rabbitmq-server

查看 RabbitMQ 狀態(tài)

# systemctl status rabbitmq-server
● rabbitmq-server.service - RabbitMQ Messaging Server
   Loaded: loaded (/lib/systemd/system/rabbitmq-server.service; enabled; vendor preset: enabled)
   Active: active (running) since Fri 2021-07-23 14:51:31 CST; 7min ago
 Main PID: 426 (beam.smp)
   Status: "Initialized"
    Tasks: 85 (limit: 2338)
   CGroup: /system.slice/rabbitmq-server.service
           ├─ 413 /bin/sh /usr/sbin/rabbitmq-server
           ├─ 426 /usr/lib/erlang/erts-9.2/bin/beam.smp -W w -A 64 -P 1048576 -t 5000000 -stbt db -zdbbl 32000 -K true -- -root /usr/lib/erlang -progname erl -- -home /var/lib/rabbitmq -- -pa
           ├─ 604 /usr/lib/erlang/erts-9.2/bin/epmd -daemon
           ├─ 904 erl_child_setup 65536
           ├─1000 inet_gethost 4
           └─1001 inet_gethost 4

RabbitMQ管理

RabbitMQ management 插件可以提供Web管理界面用來(lái)管理虛擬主機(jī)、用戶等,也可以用來(lái)管理隊(duì)列、交換機(jī)、綁定關(guān)系、策略、參數(shù)等

還可以用來(lái)監(jiān)控RabbitMQ服務(wù)的狀態(tài)及一些數(shù)據(jù)統(tǒng)計(jì)類信息 ,有興趣的可以感受一下

多租戶與權(quán)限

每一個(gè) RabbitMQ 服務(wù)器都能創(chuàng)建虛擬的消息服務(wù)器,稱為虛擬主機(jī)( Virtual Host ),簡(jiǎn)稱vhost。

每一個(gè)本質(zhì)上都是一個(gè)獨(dú)立的小型RabbitMQ服務(wù)器,擁有自己獨(dú)立的隊(duì)列、交換機(jī)及綁定關(guān)系等,并且它擁有自己獨(dú)立的權(quán)限。

Virtual Host相互之間是絕對(duì)隔離的,無(wú)法將vhost1中的交換機(jī)與vhost2中的隊(duì)列進(jìn)行綁定,這樣既保證了安全性,又可以確保可移植性

安裝好 RabbitMQ 后,會(huì)有一個(gè)默認(rèn)的 vhost 為 /

  • 使用 rabbitmqctl add_vhost xxx命令創(chuàng)建一個(gè)新的 vhost
root@xxx:/# rabbitmqctl add_vhost testvhost
Creating vhost "testvhost"
  • 刪除 vhost 的命令時(shí)rabbitmqctl delete_vhost xxx
root@xx:/# rabbitmqctl delete_vhost testvhost
Deleting vhost "testvhost"

注意

刪除一個(gè) vhost 同時(shí)也會(huì)刪除其下所有的隊(duì)列、交換機(jī)、綁定關(guān)系、用戶權(quán)限、參數(shù)和策略等信息

  • 在RabbitMQ中,權(quán)限控制是以 vhost 為單位的。

當(dāng)創(chuàng)建一個(gè)用戶時(shí),用戶通常會(huì)被指派給至少一個(gè) vhost,并且只能訪問(wèn)被指派的 vhost 內(nèi)的隊(duì)列、交換機(jī)和綁定關(guān)系等。

因此,RabbitMQ 中的授權(quán)是指在vhost級(jí)別對(duì)用戶而言的權(quán)限授予

相關(guān)的授權(quán)命令為:

rabbitmqctl set_permissions [-p vhost] {user} {conf} {write} {read}

  • vhost:授予用戶訪問(wèn)權(quán)限的 vhost 名稱,可以設(shè)置為默認(rèn)值,即vhost為 /
  • user:可以訪問(wèn)指定 vhost 的用戶名
  • conf:一個(gè)用于匹配在哪些資源上擁有可配置權(quán)限的正則表達(dá)式
  • write:一個(gè)用于匹配在哪些資源上擁有可寫權(quán)限的正則表達(dá)式
  • read:一個(gè)用于匹配在哪些資源上擁有可讀權(quán)限的正則表達(dá)式
  • 授予 root 用戶可訪問(wèn)虛擬主機(jī) testvhost,并在所有資源商都具備可配置、可寫及可讀的權(quán)限
root@xxx:/# rabbitmqctl set_permissions -p testvhost root ".*" ".*" ".*"
Setting permissions for user "root" in vhost "testvhost"
  • 列舉權(quán)限信息

用來(lái)顯示虛擬主機(jī)上的權(quán)限:rabbitmqctl list_permissions [-p vhost]

root@xxx:/# rabbitmqctl list_permissions -p testvhost
Listing permissions in vhost "testvhost"
root    .*      .*      .*

用來(lái)顯示用戶的權(quán)限:rabbitmqctl list_user_permissions {username}

root@983cebfa9073:/# rabbitmqctl list_user_permissions root 
Listing permissions for user "root"
testvhost  .*      .*      .*
/       .*      .*      .*

用戶管理

在 RabbitMQ 中,用戶是訪問(wèn)控制的基本單位

單個(gè)用戶可以跨越多個(gè) vhost 進(jìn)行授權(quán)

針對(duì)一至多個(gè) vhost ,用戶可以被賦予不同級(jí)別的訪問(wèn)權(quán)限,并使用標(biāo)準(zhǔn)的用戶名和密碼來(lái)認(rèn)證用戶

  • 創(chuàng)建用戶的命令為

rabbitmqctl add_user {username} {password}

root@xx:/# rabbitmqctl add_user root 123456
Creating user "root"
  • 更改指定用戶的密碼

rabbitmqctl change_password {username} {password}

root@xx:/# rabbitmqctl change_password root test001
Changing password for user "root"
  • 設(shè)置用戶角色

用戶的角色分為 5種 類型

角色 權(quán)限
administrator 最高權(quán)限,包含monitoring的所有權(quán)限,并且可以管理用戶、虛擬主機(jī)、權(quán)限、策略、參數(shù)等
monitoring 包含management的所有權(quán)限,并且可以看到所有連接、信道及節(jié)點(diǎn)相關(guān)信息
policymaker 包含management的所有權(quán)限,并且可以管理策略和參數(shù)
management 可以訪問(wèn)Web管理界面
none 默認(rèn)權(quán)限,無(wú)任何角色,新建的用戶默認(rèn)為none

rabbitmqctl set_user_tags {username} {tag …}

root@xx:/# rabbitmqctl set_user_tags root administrator
Setting tags for user "root" to [administrator]
  • 清除密碼

rabbitmqctl clear_password {username}

root@xx:/# rabbitmqctl clear_password root
Clearing password for user "root"
  • 驗(yàn)證用戶密碼

rabbitmqctl authenticate_user {username} {password}

root@xx:/# rabbitmqctl authenticate_user root test001
Authenticating user "root"
Success
root@xx:/# rabbitmqctl authenticate_user root 123456   
Authenticating user "root"
Error: failed to authenticate user "root"
  • 查看當(dāng)前用戶列表

rabbitmqctl list_users , 每一個(gè)用戶后面緊跟用戶的角色

root@xx:/# rabbitmqctl list_users
Listing users
root    [administrator]
  • 刪除用戶

rabbitmqctl delete_use {username}

root@xx:/# rabbitmqctl delete_user root
Deleting user "root"

Web端管理

訪問(wèn)Web管理界面

  • 本地

http://localhost:15672/

  • 遠(yuǎn)程

http://IP:15672/

Listening ports

image
Protocol Bound to Port
amqp :: 5672
clustering :: 25672
http :: 15672
  • 5672 端口

使用 amqp 協(xié)議的時(shí)候

  • 15672

訪問(wèn) web 管理頁(yè)面需要的端口

  • 25672

集群的時(shí)候,多個(gè) rabbitmq-server 相互通信的時(shí)候使用

參考資料:

RabbitMQ Tutorials

歡迎點(diǎn)贊,關(guān)注,收藏

朋友們,你的支持和鼓勵(lì),是我堅(jiān)持分享,提高質(zhì)量的動(dòng)力

image

好了,本次就到這里

技術(shù)是開(kāi)放的,我們的心態(tài),更應(yīng)是開(kāi)放的。擁抱變化,向陽(yáng)而生,努力向前行。

我是小魔童哪吒,歡迎點(diǎn)贊關(guān)注收藏,下次見(jiàn)~

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容