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

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

docker pull rabbitmq:management

在这里插入图片描述

3.启动RabbitMQ

3.1.创建并启动容器

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

在这里插入图片描述
ps:

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

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

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

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

3.3查看rabbitmq运行状况:

docker logs rabbit

3.4 访问

    http://localhost:15672

3.5 登陆
默认账号

Account  : guest
Password : guest

在这里插入图片描述

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

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>

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

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

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

}

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

Waiting for messages. 
 [x] Received 'Hello World!'
 [x] Received 'Hello World!'

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

5.Docker搭建RabbitMQ集群

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

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值