1. 程式人生 > >RabbitMQ入門(一)——RabbitMQ的安裝以及使用(Windows環境下)

RabbitMQ入門(一)——RabbitMQ的安裝以及使用(Windows環境下)

1.RabbitMQ的安裝

1、Erlang的安裝

首先,您需要安裝支援的 Windows 版Erlang。下載並執行Erlang for Windows 安裝程式。下載地址http://www.erlang.org/downloads,我是64位的所以下載的64位版本。下載完成後直接安裝,一直NEXT就行。

2、RabbitMQ安裝程式

執行RabbitMQ安裝程式rabbitmq-server-3.7.3.exe(下載地址http://www.rabbitmq.com/install-windows.html)注意版本,當前最新版本為3.7.3。它將RabbitMQ安裝為Windows服務並使用預設配置啟動它。同樣,一直NEXT就行。

3、自定義環境變數

該服務將使用其預設設定正常執行。你可以自定義RabbitMQ環境或編輯配置。 
(1)erl環境變數配置

ERLANG_HOME=C:\Program Files\erl9.2

è¿éåå¾çæè¿°
在Path中加入

%ERLANG_HOME%\bin;

è¿éåå¾çæè¿°

測試erl配置是否正確,開始-執行-cmd,輸入erl,顯示如下,證明配置正確 

è¿éåå¾çæè¿°

(2)RabbitMQ環境變數配置 
這裡注意,看好你RabbitMQ的安裝位置,以及安裝的版本,我的版本為3.7.3

è¿éåå¾çæè¿°

在Path中加入

%RABBITMQ_SERVER%\sbin;

è¿éåå¾çæè¿°

4、啟用rabbitmq_management

在CMD中鍵入如下命令

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

顯示如下:

è¿éåå¾çæè¿°

5、啟動RabbitMQ服務

直接在命令列介面鍵入如下命令

net start RabbitMQ

è¿éåå¾çæè¿°

因為RabbitMQ預設啟動的,當鍵入啟動命令時,會出現如下情況,直接關閉RabbitMQ服務,在啟動就行, 
這裡寫圖片描述 
關閉RabbitMQ服務命令如下:

net stop RabbitMQ

è¿éåå¾çæè¿°

三、RabbitMQ測試

測試地址 http://localhost:15672/ 
預設的使用者名稱:guest 
預設的密碼為:guest

è¿éåå¾çæè¿°

四、Java客戶端測試

1、RabbitMQ的jar包下載

如果你使用的是maven進行專案管理,請忽略,直接進入第二部,RabbitMQ Java客戶端的當前版本是 5.1.2。下載地址http://www.rabbitmq.com/java-client.html 

è¿éåå¾çæè¿°

2、maven專案中新增RabbitMQ依賴

直接在專案的pom.xml檔案中新增如下依賴

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

3、新建SendMQ類,傳送端(注該例項來自官網程式碼https://www.rabbitmq.com/tutorials/tutorial-one-java.html

import java.io.IOException;
import java.util.concurrent.TimeoutException;
import org.junit.Test;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;

public class SendMQ {
    private final static String QUEUE_NAME = "Hello";

    public static void main(String[] args) throws IOException, Exception {
        // connection是socket連線的抽象,並且為我們管理協議版本協商(protocol version negotiation),
        // 認證(authentication )等等事情。這裡我們要連線的訊息代理在本地,因此我們將host設為“localhost”。
        // 如果我們想連線其他機器上的代理,只需要將這裡改為特定的主機名或IP地址。
        ConnectionFactory factory = new ConnectionFactory();
        factory.setHost("localhost");
        factory.setPort(5672); //預設埠號
        factory.setUsername("guest");//預設使用者名稱
        factory.setPassword("guest");//預設密碼
        Connection connection = factory.newConnection();
        Channel channel = connection.createChannel();
        // 接下來,我們建立一個channel,絕大部分API方法需要通過呼叫它來完成。
        // 傳送之前,我們必須宣告訊息要發往哪個佇列,然後我們可以向佇列發一條訊息:
        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        String message = "Hello world";
        channel.basicPublish("", QUEUE_NAME, null, message.getBytes());
        System.out.println(" [x] Sent '" + message + "'");
        channel.close();
        connection.close();
    }
}

4、新建RecvMQ類,接收端

import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.Connection;
import java.io.IOException;
import org.junit.Test;
import com.rabbitmq.client.AMQP;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Consumer;
import com.rabbitmq.client.DefaultConsumer;
import com.rabbitmq.client.Envelope;

public class RecvMQ {
    private final static String QUEUE_NAME = "Hello";

    public static void main(String[] args) throws IOException, Exception {
        ConnectionFactory factory = new ConnectionFactory();
        factory.setHost("localhost");
        factory.setPort(5672);
        factory.setUsername("guest");
        factory.setPassword("guest");
        Connection connection = factory.newConnection();
        Channel channel = connection.createChannel();
        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        System.out.println(" [*] Waiting for messages. To exit press CTRL+C");
        Consumer consumer = new DefaultConsumer(channel) {
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties,
                    byte[] body) throws IOException {
                String message = new String(body, "UTF-8");
                System.out.println(" [x] Received '" + message + "'");
            }
        };
        channel.basicConsume(QUEUE_NAME, true, consumer);
    }

}

5、執行兩個類測試