RabbitMQ 安装教程【docker】

我用的系统是 CentOS 7

拉取镜像

官网如下

https://www.rabbitmq.com/

目前最新的版本是4.2版本,我就下载4.2版本了

复制代码
docker pull rabbitmq:4.2-management

带有 -management 后缀的版本自带 Web 管理界面

运行容器

复制代码
docker run -d \
  --name rabbitmq \
  --hostname my-rabbit \
  -p 5672:5672 \
  -p 15672:15672 \
  -v /mydata/rabbitmq:/var/lib/rabbitmq \
  -e RABBITMQ_DEFAULT_USER=snow \
  -e RABBITMQ_DEFAULT_PASS=123456 \
  --restart=always \
  rabbitmq:4.2-management

代码解释

  • -d (Detached):

后台运行。如果不加这个,容器的日志会占据你的控制台,一旦你按 Ctrl+C,服务就停了

  • --name rabbitmq:

给这个容器起个名字叫 rabbitmq

以后你可以直接用 docker stop rabbitmq 或 docker restart rabbitmq 来操作它,而不用去查随机生成的容器 ID

  • --hostname my-rabbit:

设置容器内部的虚拟主机名

每个虚拟主机相互独立,有各自的exchange、queue

如果你不指定,Docker 会生成一个随机字符串

  • -p 5672:5672:

5672 是 RabbitMQ 的 核心通信端口

Java 代码连接 MQ 时,填写的端口就是这个

  • -p 15672:15672:

15672 是 Web 管理界面的端口

在浏览器里访问页面用的就是这个端口

  • -v /mydata/rabbitmq:/var/lib/rabbitmq:

挂载数据卷

/mydata/rabbitmq 是 CentOS 宿主机 的目录(会自动创建)

/var/lib/rabbitmq 是 容器内部 存放消息数据的目录

即使你删除了这个容器,你的队列消息、交换机配置依然保存在 CentOS 的 /mydata/rabbitmq 目录下,不会丢失

  • -e RABBITMQ_DEFAULT_USER=snow:
  • -e RABBITMQ_DEFAULT_PASS=123456:

-e (Environment): 设置环境变量

设置默认登录用户名和默认登录密码,喜欢什么设置什么

  • --restart=always:

开机自启

如果 Docker 服务重启了,这个 RabbitMQ 容器会自动启动,不需要你手动去 start

  • rabbitmq:4.2-management:

指定要使用的镜像名称和版本

浏览器访问

复制代码
http://192.168.48.130:15672

换成你自己的虚拟机地址

相关推荐
熏鱼的小迷弟Liu2 小时前
【消息队列】如何在RabbitMQ中处理消息的重复消费问题?
面试·消息队列·rabbitmq
你好龙卷风!!!20 小时前
rabbitMQ入门 (mac)
macos·rabbitmq·ruby
独自破碎E1 天前
怎么在RabbitMQ中配置消息的TTL?
分布式·rabbitmq
魂之木1 天前
【零基础教程】基于Docker的RabbitMQ部署方案
分布式·docker·微服务·rabbitmq
你好龙卷风!!!1 天前
MQ相关的概念,ActiveMQ、RabbitMQ、Kafka、RocketMQ对比
rabbitmq
利刃大大1 天前
【RabbitMQ】详细使用:工作队列 && 发布/订阅模式 && 路由模式 && 通配符模式 && RPC模式 && 发布确认机制
分布式·rpc·消息队列·rabbitmq
独自破碎E1 天前
什么是RabbitMQ中的死信队列?
java·rabbitmq·java-rabbitmq
熏鱼的小迷弟Liu1 天前
【消息队列】RabbitMQ的基本架构?
面试·架构·rabbitmq
Msshu1231 天前
Type-C 多协议快充诱骗电压芯片XSP28 芯片脚耐压高达21V 电路简单 性价比高
mongodb·zookeeper·rabbitmq·flume·memcache