package main
|
|
|
|
import (
|
|
"log"
|
|
|
|
amqp "github.com/rabbitmq/amqp091-go"
|
|
rabbitmq "github.com/wagslane/go-rabbitmq"
|
|
)
|
|
|
|
func main() {
|
|
consumer, err := rabbitmq.NewConsumer(
|
|
"amqp://guest:guest@localhost", amqp.Config{},
|
|
rabbitmq.WithConsumerOptionsLogging,
|
|
)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
err = consumer.StartConsuming(
|
|
func(d rabbitmq.Delivery) bool {
|
|
log.Printf("consumed: %v", string(d.Body))
|
|
// true to ACK, false to NACK
|
|
return true
|
|
},
|
|
"my_queue",
|
|
[]string{"routing_key", "routing_key_2"},
|
|
rabbitmq.WithConsumeOptionsConcurrency(10),
|
|
rabbitmq.WithConsumeOptionsQueueDurable,
|
|
rabbitmq.WithConsumeOptionsQuorum,
|
|
rabbitmq.WithConsumeOptionsBindingExchangeName("events"),
|
|
rabbitmq.WithConsumeOptionsBindingExchangeKind("topic"),
|
|
rabbitmq.WithConsumeOptionsBindingExchangeDurable,
|
|
)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
// block main thread so consumers run forever
|
|
forever := make(chan struct{})
|
|
<-forever
|
|
}
|