Windows環境下消息中間件RabbitMq的搭建與應用

前言html

消息中間件目前已經在不少大型的項目上獲得了運用,咱們常見的有 RabbitMq, activitymq,kafka,rocketmq,其中rocketmq是阿里本身在kafka的基礎上用java寫的一個消息中間件。在咱們使用的支付寶等應用中都有大量的使用。java

附幾種常見的mq對比圖以下:linux

 

環境搭建瀏覽器

咱們都知道大部分狀況下都是在linux系統下部署服務。可是本篇的環境是在Windows下。服務器

1.安裝Erlang 

rabbitMQ是一個在AMQP協議標準基礎上完整的,可服用的企業消息系統。它遵循Mozilla Public License開源協議,採用 Erlang 實現的工業級的消息隊列(MQ)服務器,Rabbit MQ 是創建在Erlang OTP平臺上。因此在安裝rabbitMQ以前,須要先安裝Erlang 。maven

http://www.erlang.org/download/otp_win32_R16B03.exe,須要其餘版本或者64位系統的,能夠去官網下載。ide

所有點擊「下一步」就行。this

有的選擇其餘的安裝方式,可能須要添加一下系統環境變量spa

2.安裝RabbitMQ

下載運行 :http://www.rabbitmq.com/releases/rabbitmq-server/v3.2.3/rabbitmq-server-3.2.3.exe   ,須要其餘版本或者64位系統的,能夠去官網下載。插件

依舊能夠不改變默認進行安裝。

須要注意:默認安裝的RabbitMQ 監聽端口是5672

3.配置

激活 RabbitMQ's Management Plugin

使用RabbitMQ 管理插件,能夠更好的可視化方式查看Rabbit MQ 服務器實例的狀態。

打開命令窗口:

輸入命令:

"C:\Program Files\RabbitMQ Server\rabbitmq_server-3.2.3\sbin\rabbitmq-plugins.bat" enable rabbitmq_management

重啓服務才行,使用命令:

net stop RabbitMQ && net start RabbitMQ

這時候,也許會出現這種結果:

「發生錯誤:發生系統錯誤 5。  拒絕訪問。」

問題解決方案:使用管理員打開cmd再執行此命令:

在C:\Windows\System32 找到cmd.exe 雙擊執行。

建立用戶,密碼,綁定角色

使用rabbitmqctl控制檯命令(位於C:\Program Files\RabbitMQ Server\rabbitmq_server-xxx\sbin>)來建立用戶,密碼,綁定權限等。

注意:安裝路徑不一樣的請看仔細啊。

rabbitmq的用戶管理包括增長用戶,刪除用戶,查看用戶列表,修改用戶密碼。

新增一個用戶:

rabbitmqctl.bat add_user username password

查看已有用戶及用戶的角色:

rabbitmqctl.bat list_users

此時來看下咱們當前用戶後面沒有「[administrator]」

這個administrator是幹嗎用的呢?這就涉及到用戶角色問題了:

rabbitmq用戶角色可分爲五類:超級管理員, 監控者, 策略制定者, 普通管理者以及其餘。

(1) 超級管理員(administrator)

可登錄管理控制檯(啓用management plugin的狀況下),可查看全部的信息,而且能夠對用戶,策略(policy)進行操做。

(2) 監控者(monitoring)

可登錄管理控制檯(啓用management plugin的狀況下),同時能夠查看rabbitmq節點的相關信息(進程數,內存使用狀況,磁盤使用狀況等) 

(3) 策略制定者(policymaker)

可登錄管理控制檯(啓用management plugin的狀況下), 同時能夠對policy進行管理。

(4) 普通管理者(management)

僅可登錄管理控制檯(啓用management plugin的狀況下),沒法看到節點信息,也沒法對策略進行管理。

(5) 其餘的

沒法登錄管理控制檯,一般就是普通的生產者和消費者

 

咱們也給新建的用戶username 變成 「超級管理員」 角色:

rabbitmqctl.bat set_user_tags username administrator

修改密碼:

 rabbitmqctl change_password userName newPassword

刪除已存在的用戶:

rabbitmqctl.bat delete_user username

這樣基本的配置就結束了。

而後咱們打開瀏覽器  http://localhost:15672 訪問Rabbit Mq的管理控制檯,使用剛纔建立的帳號登錄系統:

 

 

設置虛擬主機和用戶關係(默認虛擬主機名爲 "/」),選中admin菜單,而後選中右邊的 virtual hosts 菜單,以下圖:

 

 在最下面有一個添加虛擬主機,咱們本身起好名稱點擊 add virtual host 便可。

而後再上面的列表中就能夠看到你新添加的主機,再點擊你新添加的虛擬主機,爲其分配用戶,咱們首先能夠分配咱們前面建立的username 用戶,而後也能夠在admin→users頁面添加新的用戶後,再將其添加到當前新建的虛擬主機。

對於這塊虛擬主機和用戶,我我的的理解就像是你買了一輛車(用戶),我買了一輛車(用戶), 可是咱們都得去交管所上拍照(虛擬主機)。

 

 java代碼編寫

如今環境搭好,開始進行code。

新建一個maven工程,新手可參考 https://www.cnblogs.com/JJJ1990/p/8384386.html  前半部分。

在pom文件中添加jar包引用

<dependency>
<groupId>com.rabbitmq</groupId>
<artifactId>amqp-client</artifactId>
<version>3.6.5</version>
</dependency>

發佈者

 1   public static void publisher() 
 2     {
 3         Connection connection = null;
 4         Channel channel = null;
 5         try
 6         {
 7             ConnectionFactory factory = new ConnectionFactory();
 8             factory.setHost(ConnectionFactory.DEFAULT_HOST); //設置鏈接地址 默認 localhost
 9             factory.setPort(ConnectionFactory.DEFAULT_AMQP_PORT);    //監聽端口 默認5672
10             factory.setUsername("username");  //用戶名
11             factory.setPassword("password");  //密碼
12             factory.setVirtualHost("test_vhosts"); // 虛擬主機
13             //建立與RabbitMQ服務器的TCP鏈接
14             connection  = factory.newConnection();
15             channel = connection.createChannel(); //建立通道/頻道
16             channel.queueDeclare("JQueue", true, false, false, null); //參數中的 JQueue就是咱們聲明的隊列名稱
17             String message = "First Message";             //消息體
18             channel.basicPublish("", "JQueue", null, message.getBytes());
19             System.out.println("Send Message is:'" + message + "'");            
20         }
21         catch(Exception ex)
22         {
23             ex.printStackTrace();
24         }
25         finally
26         {
27             if(channel != null)
28             {
29                 try {
30                     channel.close();
31                 } catch (IOException e) {
32                     // TODO Auto-generated catch block
33                     e.printStackTrace();
34                 } catch (TimeoutException e) {
35                     // TODO Auto-generated catch block
36                     e.printStackTrace();
37                 }
38             }
39             if(connection != null)
40             {
41                 try {
42                     connection.close();
43                 } catch (IOException e) {
44                     // TODO Auto-generated catch block
45                     e.printStackTrace();
46                 }
47             }
48         }
49     }

 

咱們先新建一個publisher()方法,在引入jar包的時候要特別注意,一樣的名稱有好幾個包,咱們統一都只引用 com.rabbitmq.client

在queueDeclare方法中 除了隊列名稱外的其他4項參數意義以下

* @param durable true if we are declaring a durable queue (the queue will survive a server restart)
* @param exclusive true if we are declaring an exclusive queue (restricted to this connection)
* @param autoDelete true if we are declaring an autodelete queue (server will delete it when no longer in use)
* @param arguments other properties (construction arguments) for the queue

消費者

 1     public static void  consumer() {
 2          Connection connection = null;
 3          Channel channel = null;
 4          try
 5          {
 6              ConnectionFactory factory = new ConnectionFactory();
 7              factory.setHost(ConnectionFactory.DEFAULT_HOST);
 8              factory.setPort(ConnectionFactory.DEFAULT_AMQP_PORT);
 9              factory.setUsername("jjj");      //注意此處的用戶名和發佈者不一樣,可是我將他們分配到了同一個虛擬主機,一樣能夠獲取發佈的消息
10              factory.setPassword("password");
11              factory.setVirtualHost("test_vhosts");
12              connection = factory.newConnection();
13              channel = connection.createChannel();
14   
15              Consumer consumer = new DefaultConsumer(channel) {
16                  @Override
17                  public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body)
18                          throws IOException {
19                      String message = new String(body, "UTF-8");
20                      System.out.println(" Consumer have received '" + message + "'");
21                  }
22              };
23              channel.basicConsume("JQueue", true, consumer);   //綁定消費者和隊列
24          }
25          catch(Exception ex)
26          {
27              ex.printStackTrace();
28          }
29     }

  對比消費者和發佈者的代碼咱們能夠發現,我用了不一樣的用戶鏈接同一個虛擬主機 test_vhosts

新建main方法

1 public static void main( String[] args )
2     {
3         publisher();
4         System.out.println( "Hello World!消息已經發佈" );
5         consumer();
6         System.out.println( "Hello World!正在監聽接收" );
7     }

 

運行代碼後能夠看到以下結果:

 

瀏覽器打開rabbitmq界面。找到queues 菜單,點擊後,就能夠在列表中找到咱們創建的隊列,找到我剛纔新建的jqueue隊列,點進去後,找到下面的 publish message  目錄

在Payload 中咱們隨便輸入一些文字 點擊發布就能夠看到代碼的控制檯已經收到了這些消息

 

控制檯輸出:

這說明程序運行後,消費者一直在監聽當前的隊列,一旦有消息,就會馬上獲取。

相關文章
相關標籤/搜索