rabbitmq 工作模式

package main

import (
    "fmt"
    "github.com/streadway/amqp"
    "log"
    "time"
)

func failOnError(err error, msg string) {
    if err != nil {
        log.Fatalf("%s: %s", msg, err)
    }
}

func xiaofei(name string) {
    dial, err := amqp.Dial("amqp://guest:guest@192.168.1.187:5673/")
    failOnError(err, "链接失败")
    channel, err := dial.Channel()
    failOnError(err, "channel链接失败")
    defer channel.Close()
    declare, err := channel.QueueDeclare(
        "task_queue",
        true,
        false,
        false,
        false,
        nil,
    )

    failOnError(err, "Failed to declare a queue")

    err = channel.Qos(
        1,     // prefetch count
        0,     // prefetch size
        false, // global
    )
    failOnError(err, "Failed to set QoS")
    msgs, err := channel.Consume(
        declare.Name, // queue
        "",           // consumer
        false,        // auto-ack
        false,        // exclusive
        false,        // no-local
        false,        // no-wait
        nil,          // args
    )
    failOnError(err, "Failed to register a consumer")

    forever := make(chan bool)

    go func() {
        for d := range msgs {
            fmt.Println("内容", string(d.Body), "协成", name)
            d.Ack(false)
        }
    }()
    <-forever
}

// channel 练习
func main() {
    go xiaofei("1")
    go xiaofei("2")
    dial, err := amqp.Dial("amqp://guest:guest@192.168.1.187:5673/")
    failOnError(err, "链接失败")
    channel, err := dial.Channel()
    failOnError(err, "channel链接失败")
    defer channel.Close()
    declare, err := channel.QueueDeclare(
        "task_queue",
        true,
        false,
        false,
        false,
        nil,
    )
    failOnError(err, "创建队列错误")
    for i := 0; i < 50; i++ {
        body := fmt.Sprintln("信息", i)
        channel.Publish("", declare.Name, false, false, amqp.Publishing{DeliveryMode: amqp.Persistent, ContentType: "text/plain", Body: []byte(body)})
        failOnError(err, "Failed to publish a message")
    }

    time.Sleep(10 * time.Second)
}

 

posted @ 2022-06-09 14:21  酷酷的城池  阅读(7)  评论(0编辑  收藏  举报