我們一起來學RabbitMQ 四,RabbitMQ windows 安裝

小魔童哪吒發表於2021-10-10

下載 RabbitMQ

www.rabbitmq.com/install-windows.h...

搜尋關鍵字 Download

下載 erlang 環境安裝包下

www.erlang.org/downloads

安裝配置erlang

點選上述下載的 otp_win64_24.0.exe

一直 next 即可,記住自己的安裝路徑,使用預設的即可,若自定義,最好全路徑都是英文

新建環境變數

  • 新建系統變數 - 鍵入變數名 ERLANG_HOME

  • %ERLANG_HOME%\bin 新增到 Path 路徑下

  • 進入 cmd 檢視效果

image-

如上圖效果,即為安裝配置 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

會看到上述效果,三個外掛被啟動了

  • 網頁上檢視效果

    localhost:15672/

    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管理介面

  • 本地

localhost:15672/

  • 遠端

IP:15672/

Listening ports

Protocol Bound to Port
amqp :: 5672
clustering :: 25672
http :: 15672
  • 5672 埠

使用 amqp 協議的時候

  • 15672

訪問 web 管理頁面需要的埠

  • 25672

叢集的時候,多個 rabbitmq-server 相互通訊的時候使用

參考資料:

RabbitMQ Tutorials

歡迎點贊,關注,收藏

朋友們,你的支援和鼓勵,是我堅持分享,提高質量的動力

好了,本次就到這裡

技術是開放的,我們的心態,更應是開放的。擁抱變化,向陽而生,努力向前行。

我是小魔童哪吒,歡迎點贊關注收藏,下次見~

本作品採用《CC 協議》,轉載必須註明作者和本文連結

相關文章