golang使用rabbitmq(四)路由功能

本文介绍了如何在Golang中利用RabbitMQ的路由功能,通过Direct交换器实现日志系统的优化,将告警和错误日志存储,普通日志打印到控制台。内容涵盖路由、绑定、Direct交换器的工作原理以及多绑定和日志的分发与订阅操作。
摘要由CSDN通过智能技术生成

路由

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

绑定

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

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和交换器类型有关系,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值