使用 Docker 部署 RabbitMQ 的详细指南

作者:s***5581日期:2025/11/19

使用 Docker 部署 RabbitMQ 的详细指南

在现代应用程序开发中,消息队列系统是不可或缺的一部分。RabbitMQ 是一个流行的开源消息代理软件,它实现了高级消息队列协议(AMQP)。本文将详细介绍如何使用 Docker 部署 RabbitMQ,并提供一些配置和管理的技巧。

1. 前期准备

在开始之前,请确保您的系统上已经安装了 Docker。如果尚未安装,可以参考 Docker 官方文档 或我写的前面一篇文章 CentOS 上安装 Docker 的详细指南 进行安装。

2. 停止并移除现有的 RabbitMQ 容器

如果您的系统上已经运行了 RabbitMQ 容器,可以使用以下命令停止并移除它:

1docker stop rabbitmq
2docker rm rabbitmq
3

3. 启动 RabbitMQ 容器

使用以下命令启动一个新的 RabbitMQ 容器:

1# 拉取docker镜像
2docker pull rabbitmq:management
3mkdir -p /usr/local/docker/rabbitmq
4
5docker run -id --name=rabbitmq -v /usr/local/docker/rabbitmq:/var/lib/rabbitmq -p 15672:15672 -p 5672:5672 -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=admin rabbitmq:management
6

在这条命令中,我们做了以下配置:

  • -id:以交互模式启动容器并在后台运行。
  • --name=rabbitmq:为容器指定一个名称。
  • -v /usr/local/docker/rabbitmq:/var/lib/rabbitmq:将主机目录挂载到容器内的 /var/lib/rabbitmq,用于持久化数据。
  • -p 15672:15672:映射 RabbitMQ 管理页面端口。
  • -p 5672:5672:映射 RabbitMQ 消息接收端口。
  • -e RABBITMQ_DEFAULT_USER=admin:设置默认用户名。
  • -e RABBITMQ_DEFAULT_PASS=admin:设置默认密码。
4. 查看容器日志

启动容器后,可以使用以下命令查看容器日志,确保 RabbitMQ 正常启动:

1docker logs -f rabbitmq
2

5. 访问 RabbitMQ 管理界面

在浏览器中访问 http://<你的服务器地址>:15672,使用之前设置的用户名和密码(adminadmin)登录,即可访问 RabbitMQ 的管理界面。

6. 配置说明
  • 15672端口:RabbitMQ 的管理页面端口。
  • 5672端口:RabbitMQ 的消息接收端口。
  • RABBITMQ_DEFAULT_USER 环境变量:指定 RabbitMQ 的用户名。
  • RABBITMQ_DEFAULT_PASS 环境变量:指定 RabbitMQ 的密码。
7. 环境变量配置

RabbitMQ 容器通过指定环境变量的方式进行配置,这比修改配置文件便捷得多。以下是一些常用的环境变量:

  • RABBITMQ_DEFAULT_USER:默认用户名。
  • RABBITMQ_DEFAULT_PASS:默认密码。
  • RABBITMQ_ERLANG_COOKIE:Erlang 集群 cookie。
  • RABBITMQ_NODENAME:节点名称。

更多环境变量的详细信息可以参考 RabbitMQ 官方文档

8. 持久化数据

为了确保 RabbitMQ 的数据在容器重启或删除后不会丢失,我们使用了 Docker 的卷(volume)功能。通过 -v /usr/local/docker/rabbitmq:/var/lib/rabbitmq 参数,我们将主机目录挂载到容器内的 /var/lib/rabbitmq,实现数据持久化。

9. 备份与恢复

为了防止数据丢失,定期备份 RabbitMQ 的数据是非常重要的。可以使用以下命令备份数据:

1docker exec rabbitmq tar czf /backup/rabbitmq_backup.tar.gz /var/lib/rabbitmq
2

要恢复数据,可以使用以下命令:

1docker exec rabbitmq tar xzf /backup/rabbitmq_backup.tar.gz -C /
2
10. 集群配置

RabbitMQ 支持集群配置,可以通过以下步骤实现:

  1. 启动多个 RabbitMQ 容器,并确保它们可以相互通信。
  2. 在每个节点上设置相同的 RABBITMQ_ERLANG_COOKIE
  3. 使用 rabbitmqctl 命令将节点加入集群:
    docker exec rabbitmq1 rabbitmqctl stop_app
    docker exec rabbitmq1 rabbitmqctl join_cluster rabbit@rabbitmq2
    docker exec rabbitmq1 rabbitmqctl start_app
11. 性能优化

为了提高 RabbitMQ 的性能,可以考虑以下优化措施:

  • 调整 vm_memory_high_watermark 参数,控制内存使用。
  • 使用 rabbitmq_management 插件监控性能。
  • 调整 disk_free_limit 参数,确保磁盘空间充足。
12. 常见问题排查

在使用 RabbitMQ 时,可能会遇到一些常见问题。以下是一些排查方法:

  • 无法访问管理界面:检查 15672 端口是否开放,确保防火墙未阻止该端口。
  • 消息堆积:检查消费者是否正常工作,确保消息被及时处理。
  • 内存不足:调整 vm_memory_high_watermark 参数,增加内存限制。

使用 Docker 部署 RabbitMQ 的详细指南》 是转载文章,点击查看原文


相关推荐


LVS-NAT 模式负载均衡集群部署与配置
ttthe_MOon2025/11/18

LVS(Linux Virtual Server)是基于 Linux 的负载均衡群集技术,NAT 模式通过地址转换实现内外网通信与负载分发,核心是 LVS 服务器充当网关,将外网请求转发至后端 Web 服务器。 一、核心概念 1. LVS 基础 本质:作用在四层的负载均衡器,不提供网页服务,仅通过算法为后端服务器分流减压。 核心价值:解决单台服务器性能瓶颈,实现高可用(HA)和负载均衡(LB)。 集群定义:3 台以上服务器对外表现为一个整体,提供单一访问入口(IP / 域名)。 2. NAT 模


关于No Chatbot的思考
HeteroCat2025/11/17

前言 近期在大模型圈子里,“No Chatbot”这一概念潇潇浮出江面,它意指不再将智能体局限于传统的对话式问答系统,而是发展为具备主动规划、调用工具和协作能力的智能助理。作为一名长期研究提示词工程和智能体应用的创作者,我想结合最近的思考,与大家探讨这一趋势的内涵与意义。 什么是“No Chatbot” “No Chatbot”并不是不要聊天机器人,而是指下一代智能体需要突破单纯聊天交互的框架,具备更强的自主性和执行力。它主要包含以下特征: 任务导向:关注完成复杂任务,而不是只回答问题。系统会


Spring boot启动原理及相关组件
q***38512025/11/16

优质博文:IT-BLOG-CN 一、Spring Boot应用启动 一个Spring Boot应用的启动通常如下: @SpringBootApplication @Slf4j public class ApplicationMain { public static void main(String[] args) { ConfigurableApplicationContext ctx = SpringApplication.run(ApplicationMain.


UDP服务端绑定INADDR_ANY后,客户端该用什么IP访问?
咸鱼_要_翻身2025/11/15

目录 一、问题 二、详细解释 1、INADDR_ANY 到底是什么? 2、客户端可以使用什么IP访问? 三、为什么要传IP? 1、网络层寻址的需要 2、操作系统协议栈的需要 3、服务端主机区分流量的需要 四、总结 一、问题         在UDP协议中,服务端使用INADDR_ANY了,然后客户端可以使用什么IP可以访问服务端?为什么要传IP?这是一个非常经典且重要的问题。我们来分步拆解和解答。 核心答案:当UDP服务端绑定到 INADDR_ANY (其值通常是


【Kubernetes】K8s 集群 Ingress 入口规则
陈陈CHENCHEN2025/11/14

Ingress 是管理从集群外部访问集群内部服务的入口规则(HTTP 和 HTTPS)的 API 对象,核心功能是将外部到达集群的 HTTP/HTTPS 请求,根据主机名(host)和路径(path)转发到不同的后端 Service,一起来看看如何使用吧! 1、概念 1.1、Ingress(资源) 在 K8s 中创建的 YAML 文件,只是一份规则声明,定义 “当访问 a.example.com 时,将流量转发给 service-a” 之类的规则 1.2、Ingress Control


11种方法解决iPhone上共享相册不显示的问题[2025]
Digitally2025/11/12

如果你想查看或下载朋友或家人通过iCloud链接邀请与你共享的照片,你可以利用iPhone上的共享相册功能。然而,有时这个看似无缝的过程会出现问题,让用户不禁想问:“为什么我没有收到共享相册邀请?”或“如何修复共享相册不显示”。好的,本页面致力于揭示背后的原因,并提供有效的解决方法,确保你的共享相册体验保持完美。但在那之前,让我们先简要了解一下“共享相册”。 第一部分:什么是共享相册?如何接受共享相册邀请? 什么是共享相册?“共享相册”是一个在线空间,多人可以在此添加、查看和互动照片和视频。


Java 17 密封类(Sealed Classes)实战:从类型安全到架构解耦的范式升级
听风吟丶2025/11/10

在 Java 17 之前,面向对象编程中的 “类继承” 一直存在一个痛点:一个公开类(public class)可以被任何其他类无限制继承,导致类型体系失控、代码维护成本升高。例如,定义一个 “支付方式” 基类后,开发者可能会随意继承出不符合业务逻辑的子类(如 “现金支付” 继承 “电子支付”),破坏类型体系的完整性。为解决这一问题,Java 17 正式将密封类(Sealed Classes) 纳入标准特性,通过 “显式指定子类范围”“限制继承权限”“强制类型覆盖”,从语言层面实现了类型体系的可


网络协议之传统DNS存在的问题以及httpdns
小董亮出你的8块腹肌吧!2025/11/8

写在前面 传统的DNS虽然使用的非常广泛,但是也是存在一些问题的,本文就来一起来看下,以及其解决方案http dns。 1:传统DNS存在的问题 1.1:域名缓存问题 用户某次访问时,可能已经有了距离用户更近的服务IP,但是因为还是使用缓存的那个服务IP(注意并不是不能用了),所以就无法拿到最优的那个IP了。 1.2:域名转发问题 存在这个问题的原因是,有些运营商,自己并不会取获取DNS信息,而是将这个工作转发到其他的运营商来做,而DNS服务器来返回IP地址时会根据当前请求者所在的运


Python编程实战 · 基础入门篇 | 集合(set)
程序员爱钓鱼2025/11/6

在 Python 的基础数据结构中,除了列表(list)、元组(tuple)、字典(dict),还有一种特殊但非常实用的数据类型——集合(set)。 集合的最大特点是:不重复、无序、可进行集合运算。 它常用于去重、数据筛选、关系判断等场景,是数据处理中的高效利器。 一 什么是集合(set) 集合(Set)是一种 无序、可变 的数据容器, 用于存放 不重复的元素。 在 Python 中,可以通过 {} 或 set() 创建集合。 fruits = {"apple", "banana", "ch


(3)100天python从入门到拿捏
硅基工坊2025/11/1

Python3 基本数据类型 Python 中的变量不需要声明,它没有类型,每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建 文章目录 Python3 基本数据类型一、数据类型介绍1. 数值类型(Numeric Types)1.1 整数(int)1.2 浮点数(float)1.3 复数(complex) 2. 字符串类型(String)3. 布尔类型(Boolean)4. 列表类型(List)5. 元组类型(Tuple)6. 字典类型(Dictionary)

首页编辑器站点地图

本站内容在 CC BY-SA 4.0 协议下发布

Copyright © 2025 聚合阅读