RabbitMQ 生产运维命令大全

包括:重启、扩容、迁移、故障切换、日志清理

一、、基础服务命令(所有节点通用)

bash 复制代码
# 启动
systemctl start rabbitmq-server

# 停止
systemctl stop rabbitmq-server

# 重启
systemctl restart rabbitmq-server

# 开机自启
systemctl enable rabbitmq-server

# 查看状态
systemctl status rabbitmq-server

# 查看日志(生产排错必备)
tail -f /var/log/rabbitmq/rabbitmq@$(hostname).log

二、用户 / 权限 / 后台管理

bash 复制代码
# 开启管理后台
rabbitmq-plugins enable rabbitmq_management

# 创建管理员用户
rabbitmqctl add_user admin 你的密码
rabbitmqctl set_user_tags admin administrator

# 赋权(全部权限)
rabbitmqctl set_permissions -p / admin ".*" ".*" ".*"

# 查看用户列表
rabbitmqctl list_users

# 修改密码
rabbitmqctl change_password admin 新密码

# 删除用户
rabbitmqctl delete_user 用户名

三、集群核心命令(生产高频)

bash 复制代码
# 查看集群状态(最常用)
rabbitmqctl cluster_status

# 节点停止服务(不退出集群)
rabbitmqctl stop_app

# 节点启动服务
rabbitmqctl start_app

# 重置节点(清空数据、退出集群)⚠️ 谨慎!
rabbitmqctl reset

# 加入集群(以 rmq1 为种子节点)
rabbitmqctl join_cluster rabbit@rmq1

# 将节点设置为 磁盘节点(默认)
rabbitmqctl change_cluster_node_type disc

# 将节点设置为 内存节点(一般不用)
rabbitmqctl change_cluster_node_type ram

# 从集群移除宕机节点(清理集群)
rabbitmqctl forget_cluster_node rabbit@rmq2

四、高可用镜像队列策略(最重要!必背)

1. 设置全量镜像(所有队列同步所有节点,生产标准)

复制代码
rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all","ha-sync-mode":"automatic","ha-sync-batch-size":10000}' --priority 1

2. 设置备份 2 个副本(更推荐,3 节点集群)

复制代码
rabbitmqctl set_policy ha-two "^" '{"ha-mode":"exactly","ha-params":2,"ha-sync-mode":"automatic"}' --priority 1

3. 查看策略

复制代码
rabbitmqctl list_policies

4. 删除策略

复制代码
rabbitmqctl clear_policy ha-all

五、队列、消息、连接管理(排错)

复制代码
# 查看所有队列
rabbitmqctl list_queues name messages consumers state

# 查看所有交换机
rabbitmqctl list_exchanges name type

# 查看绑定
rabbitmqctl list_bindings

# 查看连接
rabbitmqctl list_connections

# 查看通道 channels
rabbitmqctl list_channels

# 清空指定队列消息(危险!测试用)
rabbitmqctl purge_queue 队列名

# 删除队列
rabbitmqctl delete_queue 队列名

六、集群故障处理标准流程(运维必背)

场景 1:单节点宕机,重启后重新加入集群

复制代码
# 在宕机节点执行
systemctl start rabbitmq-server
rabbitmqctl stop_app
rabbitmqctl reset
rabbitmqctl join_cluster rabbit@rmq1
rabbitmqctl start_app

场景 2:节点长期挂了,从集群剔除

复制代码
# 在正常节点执行
rabbitmqctl forget_cluster_node rabbit@挂掉的节点名

场景 3:队列不同步(修复)

复制代码
rabbitmqctl sync_queue 队列名

场景 4:关闭节点优雅下线

复制代码
rabbitmqctl stop_app
# 迁移走主队列后再关机
复制代码
# Cookie 路径
/var/lib/rabbitmq/.erlang.cookie

# 必须 3 台完全一样
# 权限必须是 400,属主 rabbitmq:rabbitmq

chmod 400 /var/lib/rabbitmq/.erlang.cookie
chown rabbitmq:rabbitmq /var/lib/rabbitmq/.erlang.cookie

八、生产环境最佳实践总结

  1. 3 节点集群最稳定
  2. 镜像策略 ha-mode=all 或 exactly=2
  3. 前端必须加 LB(HAProxy/Nginx)
  4. .erlang.cookie 必须一致
  5. 队列持久化 + 消息持久化
  6. 消费者手动 ACK + 重试 + 死信
  7. 节点挂掉不影响业务,自动切换
相关推荐
tntxia1 天前
linux curl命令详解_curl详解
linux
扛枪的书生1 天前
Linux 网络管理器用法速查
linux
顺风尿一寸1 天前
Java Socket 内核之旅:从 SocketChannel.read() 到 tcp_recvmsg 与 epoll 的完整调用链路
linux
XIAOHEZIcode1 天前
Ubuntu 终端美化全栈指南:Bash 到 Kitty 踩坑实录
linux·ubuntu·命令行
唐青枫2 天前
别再只会用 cron:Linux systemd Timer 定时任务实战详解
linux
AlfredZhao3 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
戴为沐5 天前
Linux内存扩容指南
linux
zylyehuo5 天前
Linux 彻底且安全地删除文件
linux
用户805533698035 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户034095297915 天前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux