golang使用rabbitmq路由功能

Posted 吴冬冬

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了golang使用rabbitmq路由功能相关的知识,希望对你有一定的参考价值。

路由

上一章我们讲的是一个简单的日志系统,把日志广播到每一个接受者。在这一章增加一点功能,为了节省磁盘,只有告警日志和错误日志才进行存储,其他日志就打印到控制台就可以了。

绑定

上一章我们也讲过绑定,绑定是让队列和交换器之间的关系。通俗点说就是让队列只对它所绑定的交换器中的信息感兴趣。

for _, key := range os.Args[1:] 
		log.Printf("Binding queue %s to exchange %s with routing key %s",
			q.Name, "logs_direct", key)
		err = ch.QueueBind(q.Name, key, "logs_direct", false, nil)
		failOnError(err, "Failed to bind a queue")
	

绑定时的key和交换器类型有关系,如果在fanout交换器中这个值就会被忽略,而在direct交换器中的作用要看下面的内容。

Direct交换器

我们上一篇的日志系统,会把日志发送到所有的消费者。现在扩展以下,把警告和错误日志才存储到文件中,而普通信息打印到控制台即可。

fanout交换器就做不到这么灵活了,这时候就需要direct交换器。direct交换器也很简单就是把发送时带有routing key的消息发送到通过binding key绑定到交换器的队列中,这两个值要相同才可以发送。

多绑定

相同binding key值可以绑定多个队列,一个队列也可以通过多个binding key值绑定

分发日志

首先创建direct交换器

err = ch.ExchangeDeclare("logs_direct", amqp.ExchangeDirect, true, false, false, false, nil)
	failOnError(err, "Failed to declare an exchange")

然后往交换器里发送信息

body := bodyFrom(os.Args)
	err = ch.Publish("logs_direct", severityFrom(os.Args), false, false, amqp.Publishing
		DeliveryMode: amqp.Persistent,
		ContentType:  "text/plain",
		Body:         []byte(body),
	)
	failOnError(err, "Failed to publish a message")

订阅

现在进行订阅


	q, err := ch.QueueDeclare("", false, false, true, false, nil)
	failOnError(err, "Failed to declare a queue")

	if len(os.Args) < 2 
		log.Printf("Usage: %s [info] [warning] [error]", os.Args[0])
		os.Exit(0)
	

	for _, key := range os.Args[1:] 
		log.Printf("Binding queue %s to exchange %s with routing key %s",
			q.Name, "logs_direct", key)
		err = ch.QueueBind(q.Name, key, "logs_direct", false, nil)
		failOnError(err, "Failed to bind a queue")
	

	msgs, err := ch.Consume(q.Name, "", true, false, false, false, nil)
	failOnError(err, "Failed to register a consumer")

以上是关于golang使用rabbitmq路由功能的主要内容,如果未能解决你的问题,请参考以下文章

golang使用rabbitmq路由功能

Golang操作Rabbitmq

Golang操作Rabbitmq

RabbitMQ学习2---使用场景

golang RabbitMQ重新连接功能的示例。包括恢复已注册的消费者。

RabbitMQ的几种典型使用场景