Rabbitmq 消费者 : Exception (504) Reason: “channel/connection is not open“

Rabbitmq 消费者 : Exception (504) Reason: “channel/connection is not open”

启动微服务 Rabbitmq 时,定位 ch.consume() 出现异常

一、问题分析

分析日志:no exchange ‘log_topic’

> docker logs rabbitMQ_1
2023-02-10 04:17:17.221260+00:00 [error] <0.834.0> Channel error on connection <
0.819.0> (172.19.0.1:51534 -> 172.19.0.4:5672, vhost: '/', user: 'guest'), chann
el 2:
2023-02-10 04:17:17.221260+00:00 [error] <0.834.0> operation queue.bind caused a
 channel exception not_found: no exchange 'log_topic' in vhost '/'

二、检查代码

  1. consumer.go 中,ch.QueueBind 绑定在 “log_topic”
func (consumer *Consumer) Listen(topics []string) error {
	ch, err := consumer.conn.Channel()
	if err != nil {
		log.Println("channel: ", err)
		return err
	}
	defer ch.Close()

	q, err := declareRandomQueue(ch)
	if err != nil {
		log.Println("declareRandomQueue: ", err)
		return err
	}

	for _, tpoic := range topics {
		ch.QueueBind(
			q.Name,
			tpoic,
			"log_topic",
			false,
			nil,
		)

		if err != nil {
			return err
		}
	}

	msg, err := ch.Consume(q.Name, "", true, false, false, false, nil)
	if err != nil {
		log.Println("message: ", err)
		return err
	}

	forever := make(chan bool)
	go func() {
		for d := range msg {
			var payload Payload
			_ = json.Unmarshal(d.Body, &payload)

			go handlePayload(payload)
		}
	}()
	fmt.Printf("Waiting for message on [Exchange, Queue] [log_topic, %s\n]", q.Name)
	<-forever

	return nil
}
  1. event.go 中,ch.ExchangeDeclare 配置的是 “logs_topic”
func declareExchange(ch *amqp.Channel) error {
	return ch.ExchangeDeclare(
		"logs_topic", //name
		"topic",     //type
		true,        //durable
		false,       //auto delete
		false,       //internal
		false,       //no wait
		nil,         //arguements
	)
}

三、优化代码

定义一个常量 channelName,代码中使用这个常量

const channelName string = "log_topic"
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值