我們一起來學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

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

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

新建環(huán)境變量

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

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

安裝配置 RabbitMQ server

image

會看到上述效果,三個插件被啟動了

賬號:guest

密碼:guest

image

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

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

RabbitMQ ubuntu 安裝

咱們再來看看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 狀態(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管理界面用來管理虛擬主機、用戶等,也可以用來管理隊列、交換機、綁定關(guān)系、策略、參數(shù)等

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

多租戶與權(quán)限

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

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

Virtual Host相互之間是絕對隔離的,無法將vhost1中的交換機與vhost2中的隊列進行綁定,這樣既保證了安全性,又可以確??梢浦残?/p>

安裝好 RabbitMQ 后,會有一個默認的 vhost 為 /

  • 使用 rabbitmqctl add_vhost xxx命令創(chuàng)建一個新的 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 同時也會刪除其下所有的隊列、交換機、綁定關(guān)系、用戶權(quán)限、參數(shù)和策略等信息

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

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

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

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

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

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

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

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

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

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

用戶管理

在 RabbitMQ 中,用戶是訪問控制的基本單位

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

針對一至多個 vhost ,用戶可以被賦予不同級別的訪問權(quá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)限,并且可以管理用戶、虛擬主機、權(quán)限、策略、參數(shù)等
monitoring 包含management的所有權(quán)限,并且可以看到所有連接、信道及節(jié)點相關(guān)信息
policymaker 包含management的所有權(quán)限,并且可以管理策略和參數(shù)
management 可以訪問Web管理界面
none 默認權(quá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"
  • 驗證用戶密碼

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

  • 本地

http://localhost:15672/

  • 遠程

http://IP:15672/

Listening ports

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

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

  • 15672

訪問 web 管理頁面需要的端口

  • 25672

集群的時候,多個 rabbitmq-server 相互通信的時候使用

參考資料:

RabbitMQ Tutorials

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

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

image

好了,本次就到這里

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

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

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

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

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