包括:重启、扩容、迁移、故障切换、日志清理
一、、基础服务命令(所有节点通用)
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
# 迁移走主队列后再关机
七、Erlang Cookie 一致性(集群成败关键)
# 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
八、生产环境最佳实践总结
- 3 节点集群最稳定
- 镜像策略 ha-mode=all 或 exactly=2
- 前端必须加 LB(HAProxy/Nginx)
- .erlang.cookie 必须一致
- 队列持久化 + 消息持久化
- 消费者手动 ACK + 重试 + 死信
- 节点挂掉不影响业务,自动切换