RabbitMQ入门(一)——RabbitMQ的安装以及使用(Windows环境下)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/lgw_999/article/details/83346849

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、运行两个类测试

猜你喜欢

转载自blog.csdn.net/lgw_999/article/details/83346849
今日推荐