RabbitMQ-operation queue.declare caused a channel exception precondition_failed错误
今天早上有个同事在RabbitMQ服务器上做测试时,连续publish message两次都导致RabbitMQ服务挂掉,进程直接中止。但是按照他的描述我发布同样的消息,却是正常的。第一反应是查看日志,进入mq的日志目录,默认位置为:

打开rabbit@xxxx.log:

可以很明显的看到错误描述:队列message_push_default_queue的死信交换机本应该为dlx.message_push_default_exchange,但是实际上声明它的属性时指定的死信交换机却是dlx.message_push_default_exchange-message_push_default_queue,导致channel发生了异常,RabbitMQ服务中止。
(queue已经存在,但是启动 consumer 时试图设定一个 x-dead-letter-exchange 参数,这和服务器上的定义不一样,server 不允许所以报错。如果删除 queue 重新 declare 则不会有问题。或者通过 policy 来设置这个参数也可以不用删除队列。)
打开mq的web操作界面,查看message_push_default_queue队列的属性,
死信队列确实不对,重启创建该队列的服务,再次发送消息,RabbitMQ正常推送。