织梦网站发布的哪些产品和文章放在a文件可以吗,咨询类网站模板,怎么使用dw做一个网站,html5 网站logo1.发布订阅 在Fanout模式中#xff0c;一条消息#xff0c;会被所有订阅的队列都消费。但是#xff0c;在某些场景下#xff0c;我们希望不同的消息被不同的队列消费。这时就要用到Direct类型的Exchange。
在Direct模型下#xff1a;
队列与交换机的绑定#xff0c;不能…1.发布订阅 在Fanout模式中一条消息会被所有订阅的队列都消费。但是在某些场景下我们希望不同的消息被不同的队列消费。这时就要用到Direct类型的Exchange。
在Direct模型下
队列与交换机的绑定不能是任意绑定了而是要指定一个RoutingKey路由key消息的发送方在向 Exchange发送消息时也必须指定消息的 RoutingKey。Exchange不再把消息交给每一个绑定的队列而是根据消息的Routing Key进行判断只有队列的Routingkey与消息的 Routing key完全一致才会接收到消息
2.绑定
绑定可以采用额外的routing_key参数。为了避免与Channel.Publish参数混淆我们将其称为binding key。这是我们如何使用键创建绑定的方法
err ch.QueueBind(q.Name, // queue nameblack, // routing keylogs, // exchangefalse,nil) 3.直连交换器
direct交换器背后的路由算法很简单——消息进入其binding key与消息的routing key完全匹配的队列。 绑定了两个队列的direct交换器X。第一个队列绑定键为orange第二个队列绑定为两个一个绑定键为black另一个为green。
在这种设置中使用orange路由键发布到交换器的消息将被路由到队列Q1。路由键为black或green的消息将转到Q2。所有其他消息将被丢弃。
4.多重绑定 用相同的绑定键绑定多个队列是完全合法的。在我们的示例中我们可以使用绑定键black在X和Q1之间添加绑定。在这种情况下direct交换器的行为将类似fanout并将消息广播到所有匹配的队列。带有black路由键的消息将同时传递给Q1和Q2。
5.发送日志
在日志系统中使用这个模型发送消息到direct交换器。这样接收脚本将能够选择其想要接收的日志级别。
先创建一个direct交换器
err ch.ExchangeDeclare(logs_direct, // namedirect, // typetrue, // durablefalse, // auto-deletedfalse, // internalfalse, // no-waitnil, // arguments
)指定routing key发送一条消息
body : bodyFrom(os.Args)
err ch.Publish(logs_direct, // exchangeseverityFrom(os.Args), // routing keyfalse, // mandatoryfalse, // immediateamqp.Publishing{ContentType: text/plain,Body: []byte(body),
})为了简化问题我们假设“严重性”可以是“info”、“warning”、“error”之一。
6.订阅
为感兴趣的每种严重性日志级别创建一个新的绑定。绑定的routing key通过os.Args获取
q, err : ch.QueueDeclare(, // namefalse, // durablefalse, // delete when unusedtrue, // exclusivefalse, // no-waitnil, // arguments
)
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 _, s : range os.Args[1:] {log.Printf(Binding queue %s to exchange %s with routing key %s,q.Name, logs_direct, s)err ch.QueueBind(q.Name, // queue names, // routing keylogs_direct, // exchangefalse,nil)failOnError(err, Failed to bind a queue)
}7.完整示例 emit_log_direct.go脚本的代码
package mainimport (logosstringsgithub.com/streadway/amqp
)func failOnError(err error, msg string) {if err ! nil {log.Fatalf(%s: %s, msg, err)}
}func main() {conn, err : amqp.Dial(amqp://guest:guestlocalhost:5672/)failOnError(err, Failed to connect to RabbitMQ)defer conn.Close()ch, err : conn.Channel()failOnError(err, Failed to open a channel)defer ch.Close()err ch.ExchangeDeclare(logs_direct, // namedirect, // typetrue, // durablefalse, // auto-deletedfalse, // internalfalse, // no-waitnil, // arguments)failOnError(err, Failed to declare an exchange)body : bodyFrom(os.Args)err ch.Publish(logs_direct, // exchangeseverityFrom(os.Args), // routing keyfalse, // mandatoryfalse, // immediateamqp.Publishing{ContentType: text/plain,Body: []byte(body),})failOnError(err, Failed to publish a message)log.Printf( [x] Sent %s, body)
}func bodyFrom(args []string) string {var s stringif (len(args) 3) || os.Args[2] {s hello} else {s strings.Join(args[2:], )}return s
}func severityFrom(args []string) string {var s stringif (len(args) 2) || os.Args[1] {s info} else {s os.Args[1]}return s
}receive_logs_direct.go的代码
package mainimport (logosgithub.com/streadway/amqp
)func failOnError(err error, msg string) {if err ! nil {log.Fatalf(%s: %s, msg, err)}
}func main() {conn, err : amqp.Dial(amqp://guest:guestlocalhost:5672/)failOnError(err, Failed to connect to RabbitMQ)defer conn.Close()ch, err : conn.Channel()failOnError(err, Failed to open a channel)defer ch.Close()err ch.ExchangeDeclare(logs_direct, // namedirect, // typetrue, // durablefalse, // auto-deletedfalse, // internalfalse, // no-waitnil, // arguments)failOnError(err, Failed to declare an exchange)q, err : ch.QueueDeclare(, // namefalse, // durablefalse, // delete when unusedtrue, // exclusivefalse, // no-waitnil, // arguments)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 _, s : range os.Args[1:] {log.Printf(Binding queue %s to exchange %s with routing key %s,q.Name, logs_direct, s)err ch.QueueBind(q.Name, // queue names, // routing keylogs_direct, // exchangefalse,nil)failOnError(err, Failed to bind a queue)}msgs, err : ch.Consume(q.Name, // queue, // consumertrue, // auto ackfalse, // exclusivefalse, // no localfalse, // no waitnil, // args)failOnError(err, Failed to register a consumer)forever : make(chan bool)go func() {for d : range msgs {log.Printf( [x] %s, d.Body)}}()log.Printf( [*] Waiting for logs. To exit press CTRLC)-forever
}如果你只想将“warning”和“err”而不是“info”级别的日志消息保存到文件中只需打开控制台并输入
go run receive_logs_direct.go warning error logs_from_rabbit.log如果你想在屏幕上查看所有日志消息请打开一个新终端并执行以下操作
go run receive_logs_direct.go info warning error
# [*] Waiting for logs. To exit press CTRLC例如要发出error日志消息只需输入
go run emit_log_direct.go error Run. Run. Or it will explode.
# [x] Sent error:Run. Run. Or it will explode.这里是emit_log_direct.go)和receive_logs_direct.go的完整源码 参考文章
go rabbitmq Routing模式 - 范斯猫 (fansimao.com)
RabbitMQ Go语言客户端教程4——路由 - 范斯猫 (fansimao.com)