极简操作RabbitMQ的Go客户端

基于https://github.com/streadway/amqp封装了一个RabbitMQ Go客户端,使用起来更方便。

安装

go get github.com/itbsl/rabbitmq

使用

使用起来,rabbitmq只包含5个创建不同类型的RabbitMQ实例的方法,和一个关闭连接的方法,以及发送消息和获取消息的的两个方法,共八个方法
方法如下:

//创建普通类型的rabbitmq实例,消息没有持久化
rabbitmq.NewSimpleRabbitMQ()
//创建工作队列模式的RabbitMQ实例:消息持久化,需要手动应答
rabbitmq.NewWorkQueueRabbitMQ()
//创建发布/订阅模式的RabbitMQ实例:消息持久化,自动应答
rabbitmq.NewPubSubRabbitMQ()
//创建路由模式的RabbitMQ实例:消息持久化,手动应答
rabbitmq.NewRouteRabbitMQ()
//创建话题模式的RabbitMQ实例:消息持久化,手动应答
rabbitmq.NewTopicRabbitMQ()

示例:

生产者客户端
1.创建RabbitMQ实例
2.发送消息

package main

import (
	"github.com/itbsl/rabbitmq"
	"log"
)

func main() {
	//连接RabbitMQ
	url := "amqp://root:root@127.0.0.1:5672/"
	mq, err := rabbitmq.NewWorkQueueRabbitMQ(url, "hello")
	if err != nil {
		log.Fatalf("连接RabbitMQ出错,错误为:%v\n", err)
	}
	defer mq.Close()

	//发送消息
	err = mq.Send("hello world!")
	if err != nil {
		log.Fatalf("发送消息失败,错误为:%v\n", err)
	}
}

消费者客户端
1.创建所需类型的RabbitMQ实例
2.消费消息,业务代码写在回调函数里

package main

import (
	"github.com/itbsl/rabbitmq"
	"log"
)

func main() {
	//连接RabbitMQ
	url := "amqp://root:root@127.0.0.1:5672/"
	mq, err := rabbitmq.NewWorkQueueRabbitMQ(url, "hello")
	if err != nil {
		log.Fatalf("连接RabbitMQ出错,错误为:%v\n", err)
	}
	defer mq.Close()

	//消费消息
	err = mq.Consume(func(msg string) bool {
		//这里写业务处理代码,业务处理成功,返回true用于手动应答,失败返回false,消息会被重新放入队列
		return true
	})
	if err != nil {
		log.Fatalf("消费失败,错误为:%v\n", err)
	}
}
posted @ 2021-02-26 18:41  itbsl  阅读(394)  评论(0编辑  收藏  举报