go语言操作rabbitmq

go 复制代码
package main

import (
	"fmt"
	"log"
	"sync"
	"time"

	"github.com/streadway/amqp"
)

func declareQueue(ch *amqp.Channel, queueName string) error {
	_, err := ch.QueueDeclare(
		queueName, // name
		false,     // durable
		false,     // delete when unused
		false,     // exclusive
		false,     // no-wait
		nil,       // arguments
	)
	return err
}

func producer(ch *amqp.Channel, wg *sync.WaitGroup, queueName string) {
	defer wg.Done()

	for i := 1; i <= 5; i++ {
		message := fmt.Sprintf("Message %d", i)

		err := ch.Publish(
			"",        // exchange
			queueName, // routing key
			false,     // mandatory
			false,     // immediate
			amqp.Publishing{
				ContentType: "text/plain",
				Body:        []byte(message),
			})

		if err != nil {
			log.Fatalf("Failed to publish a message: %v", err)
		}

		fmt.Printf("Sent: %s\n", message)
		time.Sleep(time.Second)
	}
}

func consumer(ch *amqp.Channel, wg *sync.WaitGroup, queueName string) {
	defer wg.Done()

	msgs, err := ch.Consume(
		queueName, // queue
		"",        // consumer
		true,      // auto-ack
		false,     // exclusive
		false,     // no-local
		false,     // no-wait
		nil,       // args
	)

	if err != nil {
		log.Fatalf("Failed to register a consumer: %v", err)
	}

	for msg := range msgs {
		fmt.Printf("Received: %s\n", msg.Body)
	}
}

func main() {
	conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
	if err != nil {
		log.Fatalf("Failed to connect to RabbitMQ: %v", err)
	}
	defer conn.Close()

	ch, err := conn.Channel()
	if err != nil {
		log.Fatalf("Failed to open a channel: %v", err)
	}
	defer ch.Close()

	queueName := "your_queue_name"

	// Declare the queue before using it
	err = declareQueue(ch, queueName)
	if err != nil {
		log.Fatalf("Failed to declare queue: %v", err)
	}

	var wg sync.WaitGroup
	wg.Add(2)

	go producer(ch, &wg, queueName)
	go consumer(ch, &wg, queueName)

	wg.Wait()
}

运行结果

go 复制代码
Sent: Message 1    
Received: Message 1
Sent: Message 2
Received: Message 2
Sent: Message 3
Received: Message 3
Sent: Message 4
Received: Message 4
Sent: Message 5
Received: Message 5
相关推荐
jieyucx2 分钟前
Go 语言零基础入门:标准库 log 包完全教程
golang·日志·log
会编程的土豆5 分钟前
Go 语言匿名函数详解
c++·golang·xcode
会编程的土豆8 分钟前
Go 语言闭包(Closure)详解
c++·golang·xcode
右耳朵猫AI10 分钟前
Golang技术周刊 2026年第20周
开发语言·后端·golang
会编程的土豆28 分钟前
Redis 常用操作笔记(Go 开发实战)
redis·笔记·golang
Xzh042337 分钟前
RabbitMQ 核心原理与实战指南:从入门到生产级应用
rabbitmq·rabbit·java-rabbitmq
喵了几个咪1 小时前
Headless 后端实践:基于Go的企业级多栈管理系统脚手架
开发语言·vue.js·后端·golang·reactjs·gowind
小小龙学IT1 小时前
Go 并发模式深度解析:Fan-out/Fan-in 高效处理大规模数据流
开发语言·后端·golang
OxyTheCrack12 小时前
【Golang】简述make与new内置函数以及两者的区别
开发语言·golang
会编程的土豆15 小时前
Go 方法接收者超清晰笔记(类型名 vs 变量名)
开发语言·笔记·golang