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. 节点挂掉不影响业务,自动切换
相关推荐
网安INF2 小时前
数据结构第二章复习:线性表
java·开发语言·数据结构
IMPYLH2 小时前
Linux 的 nl 命令
linux·运维·服务器·bash
aq55356002 小时前
Laravel10.X核心特性全解析
java·开发语言·spring boot·后端
咖喱o2 小时前
路由策略
linux·服务器·网络
油墨香^_^2 小时前
Spring Boot集成WebSocket,实现后台向前端推送信息
开发语言
我星期八休息2 小时前
Python-基础语法大全
开发语言·python
源代码杀手2 小时前
利用MATLAB®和Simulink®资源的可再生能源
开发语言·matlab
请数据别和我作队2 小时前
Python实现直播弹幕数据采集(WebSocket实时弹幕采集)
开发语言·网络·python·websocket·网络协议·学习分享