下載 RabbitMQ
www.rabbitmq.com/install-windows.h...
搜尋關鍵字 Download
下載 erlang 環境安裝包下
安裝配置erlang
點選上述下載的 otp_win64_24.0.exe
一直 next 即可,記住自己的安裝路徑,使用預設的即可,若自定義,最好全路徑都是英文
新建環境變數
- 新建系統變數 - 鍵入變數名 ERLANG_HOME
- %ERLANG_HOME%\bin 新增到 Path 路徑下
- 進入 cmd 檢視效果
如上圖效果,即為安裝配置 erlang 環境成功
安裝配置 RabbitMQ server
安裝上述下載的 [rabbitmq-server-3.8.19.exe](github-releases.githubusercontent.... filename%3Drabbitmq-server-3.8.19.exe&response-content-type=application%2Foctet-stream) ,一直 next 即可 ,記住自己的安裝路徑,使用預設的即可,若自定義,建議全路徑都是英文
開啟 cmd 進入目錄,例如我的目錄是 :
C:\Program Files\RabbitMQ Server\rabbitmq_server-3.8.19\sbin
執行
rabbitmq-plugins enable rabbitmq_management
會看到上述效果,三個外掛被啟動了
網頁上檢視效果
guest 使用者只能在本地訪問web 頁面
賬號:guest
密碼:guest
命令(cmd 中可以執行)
net start RabbitMQ 啟動
net stop RabbitMQ 停止
rabbitmqctl status 檢視狀態
我們們再來看看linux 中RabbitMQ 如何安裝和使用
RabbitMQ使用erlang語言寫的,所以在安裝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 狀態
# 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管理介面用來管理虛擬主機、使用者等,也可以用來管理佇列、交換機、繫結關係、策略、引數等
還可以用來監控RabbitMQ服務的狀態及一些資料統計類資訊 ,有興趣的可以感受一下
多租戶與許可權
每一個 RabbitMQ 伺服器都能建立虛擬的訊息伺服器,稱為虛擬主機( Virtual Host ),簡稱vhost。
每一個本質上都是一個獨立的小型RabbitMQ伺服器,擁有自己獨立的佇列、交換機及繫結關係等,並且它擁有自己獨立的許可權。
Virtual Host相互之間是絕對隔離的,無法將vhost1中的交換機與vhost2中的佇列進行繫結,這樣既保證了安全性,又可以確保可移植性
安裝好 RabbitMQ 後,會有一個預設的 vhost 為 /
- 使用
rabbitmqctl add_vhost xxx
命令建立一個新的 vhost
root@xxx:/# rabbitmqctl add_vhost testvhost
Creating vhost "testvhost"
- 刪除 vhost 的命令時
rabbitmqctl delete_vhost xxx
root@xx:/# rabbitmqctl delete_vhost testvhost
Deleting vhost "testvhost"
注意
刪除一個 vhost 同時也會刪除其下所有的佇列、交換機、繫結關係、使用者許可權、引數和策略等資訊
- 在RabbitMQ中,許可權控制是以 vhost 為單位的。
當建立一個使用者時,使用者通常會被指派給至少一個 vhost,並且只能訪問被指派的 vhost 內的佇列、交換機和繫結關係等。
因此,RabbitMQ 中的授權是指在vhost級別對使用者而言的許可權授予
相關的授權命令為:
rabbitmqctl set_permissions [-p vhost] {user} {conf} {write} {read}
- vhost:授予使用者訪問許可權的 vhost 名稱,可以設定為預設值,即vhost為
/
- user:可以訪問指定 vhost 的使用者名稱
- conf:一個用於匹配在哪些資源上擁有可配置許可權的正規表示式
- write:一個用於匹配在哪些資源上擁有可寫許可權的正規表示式
- read:一個用於匹配在哪些資源上擁有可讀許可權的正規表示式
- 授予 root 使用者可訪問虛擬主機 testvhost,並在所有資源商都具備可配置、可寫及可讀的許可權
root@xxx:/# rabbitmqctl set_permissions -p testvhost root ".*" ".*" ".*"
Setting permissions for user "root" in vhost "testvhost"
- 列舉許可權資訊
用來顯示虛擬主機上的許可權:rabbitmqctl list_permissions [-p vhost]
root@xxx:/# rabbitmqctl list_permissions -p testvhost
Listing permissions in vhost "testvhost"
root .* .* .*
用來顯示使用者的許可權:rabbitmqctl list_user_permissions {username}
root@983cebfa9073:/# rabbitmqctl list_user_permissions root
Listing permissions for user "root"
testvhost .* .* .*
/ .* .* .*
使用者管理
在 RabbitMQ 中,使用者是訪問控制的基本單位
單個使用者可以跨越多個 vhost 進行授權
針對一至多個 vhost ,使用者可以被賦予不同級別的訪問許可權,並使用標準的使用者名稱和密碼來認證使用者
- 建立使用者的命令為
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"
- 設定使用者角色
使用者的角色分為 5種 型別
角色 | 許可權 |
---|---|
administrator | 最高許可權,包含monitoring的所有許可權,並且可以管理使用者、虛擬主機、許可權、策略、引數等 |
monitoring | 包含management的所有許可權,並且可以看到所有連線、通道及節點相關資訊 |
policymaker | 包含management的所有許可權,並且可以管理策略和引數 |
management | 可以訪問Web管理介面 |
none | 預設許可權,無任何角色,新建的使用者預設為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"
- 驗證使用者密碼
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"
- 檢視當前使用者列表
rabbitmqctl list_users , 每一個使用者後面緊跟使用者的角色
root@xx:/# rabbitmqctl list_users
Listing users
root [administrator]
刪除使用者
rabbitmqctl delete_use {username}
root@xx:/# rabbitmqctl delete_user root
Deleting user "root"
Web端管理
訪問Web管理介面
- 本地
- 遠端
Listening ports
Protocol | Bound to | Port |
---|---|---|
amqp | :: | 5672 |
clustering | :: | 25672 |
http | :: | 15672 |
- 5672 埠
使用 amqp 協議的時候
- 15672
訪問 web 管理頁面需要的埠
- 25672
叢集的時候,多個 rabbitmq-server 相互通訊的時候使用
參考資料:
歡迎點贊,關注,收藏
朋友們,你的支援和鼓勵,是我堅持分享,提高質量的動力
好了,本次就到這裡
技術是開放的,我們的心態,更應是開放的。擁抱變化,向陽而生,努力向前行。
我是小魔童哪吒,歡迎點贊關注收藏,下次見~
本作品採用《CC 協議》,轉載必須註明作者和本文連結