极简操作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)
        }
}