当前位置:   article > 正文

Docker 部署RabbitMQ_docker rabbitmq

docker rabbitmq

目录:
1.简介
2.部署RabbitMQ
3.启动RabbitMQ
4.实操消费
5.Docker搭建RabbitMQ集群

1.简介

该实例为了巩固docker知识
MQ全称Message Queue 消息队列,RabbitMQ是基于AMQP(高级消息队列协议)实现的。消息队列通常用以应用之间相互通信,解决同步问题,在项目中用到该消息队列,但是环境在服务器上(各种跳板),有时候自己测试不方便,故用docker搭建RabbitMQ本地环境,方便测试调试.
后续有关RabbitMQ的学习和深入就基于这个容器实操.

2.部署RabbitMQ

1、查询rabbitmq镜像

docker search rabbitmq:management
  • 1

在这里插入图片描述
2、拉取rabbitmq镜像

docker pull rabbitmq:management
  • 1

在这里插入图片描述

3.启动RabbitMQ

3.1.创建并启动容器

docker run -d --hostname my-rabbit --name rabbit -p 8080:15672 rabbitmq:management
  • 1

在这里插入图片描述
ps:

--hostname:指定容器主机名称
--name:指定容器名称
-p:将mq端口号映射到本地
  • 1
  • 2
  • 3

3.2备选启动同时设置用户和密码

docker run -d --hostname my-rabbit --name rabbit -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=admin -p 15672:15672 -p 5672:5672 -p 25672:25672 -p 61613:61613 -p 1883:1883 rabbitmq:management
  • 1

ps: 此处的端口访问是有区别的,控制台端口用于管理rabbitmq,应用访问端口号为rabbitclient等应用访问。

15672:控制台端口号
 5672:应用访问端口号
  • 1
  • 2

3.3查看rabbitmq运行状况:

docker logs rabbit
  • 1

3.4 访问

    http://localhost:15672
  • 1

3.5 登陆
默认账号

Account  : guest
Password : guest
  • 1
  • 2

在这里插入图片描述

4.实操(Java)

启动Rabbit

docker run -d --hostname my-rabbit --name rabbit -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=admin -p 15672:15672 -p 5672:5672 -p 25672:25672 -p 61613:61613 -p 1883:1883 rabbitmq:management
  • 1

ps:所用user>>> admin/admin

添加pom.xml依赖

    <dependencies>
        <!-- https://mvnrepository.com/artifact/com.rabbitmq/amqp-client -->
        <dependency>
            <groupId>com.rabbitmq</groupId>
            <artifactId>amqp-client</artifactId>
            <version>3.6.5</version>
        </dependency>
    </dependencies>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

发送端(运行发送端,连续发送两条信息到指定队列)

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import java.util.concurrent.TimeoutException;

/**
 * @Auther: chenyj
 * @Date: 2018/12/4 10:58
 * @Description:
 */
public class Sender {
    //队列名称
    private final static String QUEUE_NAME = "hello";

    public static void main(String[] argv)throws java.io.IOException, TimeoutException {
        ConnectionFactory factory = new ConnectionFactory();
        //Account
        factory.setUsername("admin");
        //Password
        factory.setPassword("admin");
        //rabbit所在服务器主机名
        factory.setHost("192.168.209.128");
        //应用访问端口
        factory.setPort(5672);
        //指定RabbitMQ服务器的虚拟主机
        factory.setVirtualHost("/");
        //创建连接
        Connection connection = factory.newConnection();
        Channel channel = connection.createChannel();
        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();
    }
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38

UI查看
ps: 方才发送了两条信息
在这里插入图片描述

消费端

import com.rabbitmq.client.*;

import java.io.IOException;

/**
 * @Auther: chenyj
 * @Date: 2018/12/4 11:05
 * @Description:
 */
public class Receiver {
    //队列名称
    private final static String QUEUE_NAME = "hello";

    public static void main(String[] argv) throws Exception {
        ConnectionFactory factory = new ConnectionFactory();
        //Account
        factory.setUsername("admin");
        //Password
        factory.setPassword("admin");
        //rabbit所在服务器主机名
        factory.setHost("192.168.209.128");
        //应用访问端口
        factory.setPort(5672);
        //指定RabbitMQ服务器的虚拟主机
        factory.setVirtualHost("/");
        //连接参数
        factory.setConnectionTimeout(600000); // in milliseconds
        factory.setRequestedHeartbeat(60); // in seconds
        factory.setHandshakeTimeout(6000); // in milliseconds
        factory.setRequestedChannelMax(5);
        factory.setNetworkRecoveryInterval(500);

        Connection connection = factory.newConnection();
        Channel channel = connection.createChannel();

        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        System.out.println("Waiting for messages. ");

        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);
    }

}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51

运行上述消费者,控制台输出

Waiting for messages. 
 [x] Received 'Hello World!'
 [x] Received 'Hello World!'
  • 1
  • 2
  • 3

此时Rabbit页面已经全部消费成功
在这里插入图片描述

5.Docker搭建RabbitMQ集群

暂时没该需求,如有用到的小伙伴可以参考一下博客
https://blog.csdn.net/belonghuang157405/article/details/83540148

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/981651
推荐阅读
相关标签
  

闽ICP备14008679号