RabbitMQ安裝配置和基於EasyNetQ驅動的基礎使用


RabbitMQ基本概念和原理

1.AMQP,即Advanced Message Queuing Protocol,高級消息隊列協議,是應用層協議的一個開放標准,為面向消息的中間件設計。

2.RabbitMQ是一個開源的AMQP實現,服務器端用Erlang語言編寫。

3.Channel 

  Channel是我們與RabbitMQ打交道的最重要的一個接口,我們大部分的業務操作是在Channel這個接口中完成的,包括定義Queue、定義Exchange、綁定Queue與Exchange、發布消息等。

4.Exchange(生產者將消息發送到Exchange(交換器),由Exchange將消息路由到一個或多個Queue中(或者丟棄),RabbitMQ常用的Exchange Type有fanout、direct、topic、headers這四種)

5.Queue(RabbitMQ的內部對象,用於存儲消息)

6.基本工作原理

 客戶端(生產者) send Message -->Exchange (交換機通過不同的類型將消息保存到對應的queue)-->Queue  

 客戶端(消費者)通過訂閱來消費queue中的消息。

 以上基礎概念整理來源於 RabbitMQ基礎概念詳細介紹 

在Windows系統中安裝RabbitMQ

  1. 下載安裝erlang (我用的是otp_win64_19.3版本)  

      下載地址 http://www.erlang.org/downloads(根據操作系統選擇32還64位)  

  2. 下載安裝rabbitmq-server(我用的是rabbitmq-server-3.6.10版本)

     下載地址 http://www.rabbitmq.com/install-windows.html

     安裝好后,在看裝目錄下看到

    

     接下來用啟用DOS命令

a. cd 到sbin目錄下,我的安裝目錄是D:\RabbitMQServer\rabbitmq_server-3.6.10\sbin, 輸入D: 回車,cd  RabbitMQServer\rabbitmq_server-3.6.10\sbin

 

b. 查看安裝是否成功命令 :rabbitmqctl status

c.安裝管理插件命令:rabbitmq-plugins enable rabbitmq_management

安裝成功,在瀏覽器中輸入 http://127.0.0.1:15672/

 

輸入來賓賬號 guest 密碼 guest ,成功登陸進來,是不是有點小激動。

 guest 賬號是管理員賬號,可以添加Exchanges,Queues,Admin。但我們一般不使用guest賬號,繼續用命令來添加賬號和權限。

d:添加用戶:rabbitmqctl.bat add_user username password

 

e:添加“超級管理員”角色: rabbitmqctl.bat set_user_tags username administrator

 

mymq賬號也是超級管理員了,Can access virtual hosts :No access ,可以看到還沒有能夠訪問的虛擬機,接下來添加虛擬機。

f: 添加虛擬機:  rabbitmqctl add_vhost vhostName

 myvhost虛擬機並沒有Users,接下來給虛擬機綁定賬號。

g:定虛擬機和用戶權限:rabbitmqctl set_permissions -p 虛擬機名稱 賬戶名 ".*" ".*" ".*"

 

h:處於習慣我一般刪除掉guest賬號:rabbitmqctl.bat delete_user username

 好了,重新登陸管理頁面,一切正常,接下來開始實戰了。 

EasyNetQ的基本使用

項目中安裝EasyNetQ

EasyNetQ是依賴於RabbitMQ.Client的,所以會被一並安裝到項目中。

Publish發布消息

 

Model有個Queue的特性,定義Queue名稱和Exchange名稱。然后直接用Publish方法把Msg通過Model指定的交換機推送到指定隊列去。

運行代碼,看看MQ的管理頁面。

 已經創建了Model指定的交換機TestQueue.Exchange, Type:topic , Features:D 。D:Durable 說明默認創建的交換機是持久化的。

 因為還沒有訂閱消息,所以在Queues中還看不到對應的隊列。

 Subscribe訂閱消息

  

 為什么要在訂閱代碼上套一個while(true)了? 是為了把控制台程序模擬成Windows服務,因為控制台程序運行一閃而過,沒辦法真正訂閱到MQ的消息。

 實際開發中,一般用Topself來把控制台程序發布成Windows服務,后面有時間再寫一篇關於Topself的學習博客。

 再重復剛才的Publish操作,測試下整個流程。

 

自定義Topic

這樣消息會被發送到名稱為Test.開頭的所有Queue隊列中。

SendReceive

通過send和receive可以將消息發送到指定隊列。

 

本文博客園地址:http://www.cnblogs.com/struggle999/p/6937530.html 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM