go队列方式集成rabbitMq

rabbitMq集成(rabbitMq.go)

package rabbitMQ

import (
	"github.com/streadway/amqp"
	"smartracing.cn/appointment/member/internal/conf"
)

type Delivery func(<-chan amqp.Delivery)

type MQServer interface {
	CreateQueue(string) (amqp.Queue, error)
	Publish(string, []byte) error
	RegisterConsumer(qName string, delivery Delivery)
	StartConsumer()
}

type RabbitMQ struct {
	conn       *amqp.Connection
	callback   map[string]Delivery
	connNotify chan *amqp.Error
}

func (rabbitmq *RabbitMQ) RegisterConsumer(qName string, delivery Delivery) {
	rabbitmq.callback[qName] = delivery
}

// 新建rabbitMq连接
func New(uri string) (MQServer, error) {
	conn, err := amqp.Dial(uri)
	if err != nil {
		return nil, err
	}
	rabbit := &RabbitMQ{conn: conn, callback: make(map[string]Delivery)}
	return rabbit, nil
}

// 创建队列
func (rabbitmq *RabbitMQ) CreateQueue(qName string) (amqp.Queue, error) {
	ch, err := rabbitmq.conn.Channel()
	if err != nil {
		return amqp.Queue{}, err
	}
	defer ch.Close()
	queue, err := ch.QueueDeclare(qName, true, false, false, false, nil)
	if err != nil {
		return amqp.Queue{}, err
	}
	return queue, nil
}

// 发布者
func (rabbitmq *RabbitMQ) Publish(qName string, body []byte) error {
	queue, err := rabbitmq.CreateQueue(qName)
	ch, err := rabbitmq.conn.Channel()
	if err != nil {
		return err
	}
	defer ch.Close()
	err = ch.Publish(
		"",
		queue.Name,
		false,
		false,
		amqp.Publishing{
			DeliveryMode: amqp.Persistent,
			ContentType:  "application/json",
			Body:         body,
		})
	if err != nil {
		return err
	}
	conf.Log.Infof("rabbitMQ publish queue:%s, message:%s", qName, string(body))
	return nil
}

func SendRabbitMQ(queue string, body []byte) error {
	r, err := New(conf.AppConfig.RabbitMqUrl)
	if err != nil {
		conf.Log.Errorf("New RabbitMQ Fatal:%v", err)
		return err
	}
	if err := r.Publish(queue, body); err != nil {
		return err
	}
	return nil
}

// 消费者
func (rabbitmq *RabbitMQ) StartConsumer() {
	for queue, delivery := range rabbitmq.callback {
		go func(qName string, delivery Delivery) {
			queue, err := rabbitmq.CreateQueue(qName)
			if err != nil {
				conf.Log.Fatalf("rabbitmq create queue fatal:%v", err)
				panic(err.Error())
			}

			ch, err := rabbitmq.conn.Channel()
			if err != nil {
				conf.Log.Fatalf("rabbitmq channel fatal:%v", err)
				panic(err.Error())
			}
			defer ch.Close()

			err = ch.Qos(
				3,
				0,
				false,
			)
			if err != nil {
				conf.Log.Fatalf("rabbitmq qos fatal:%v", err)
				panic(err.Error())
			}

			msgs, err := ch.Consume(queue.Name, "", false, false, false, false, nil)
			if err != nil {
				conf.Log.Fatalf("rabbitmq consume fatal:%v", err)
				panic(err.Error())
			}
			conf.Log.Infof("rabbitmq add consume success, consume:%s, delivery:%v", queue, delivery)
			go delivery(msgs)
			select {}
		}(queue, delivery)
	}
}

创建消费者

package rabbitMQ

import (
	"encoding/json"
	"fmt"
	"github.com/streadway/amqp"
	"smartracing.cn/appointment/member/internal/conf"
)

type MqData struct {
	ID   string `json:"id"`
	Name string `json:"name"`
}

func TextMqConsumer(delivery <-chan amqp.Delivery) {
	for msg := range delivery {
		conf.Log.Infof("Received TextDetectResult: %s", msg.Body)
		fmt.Printf("Received TextDetectResult: %s\n", msg.Body)
		var data MqData
		json.Unmarshal(msg.Body, &data)
		msg.Ack(false)
	}
}

发布消息

// 发送关注mq
	mqData := map[string]interface{}{"uId": claims.Uid, "followId": memberId, "type": 1}
	dataBytes, _ := json.Marshal(mqData)
	errMq := rabbitMQ.SendRabbitMQ("subscribe", dataBytes)
	if errMq != nil {
		conf2.Log.Error(errMq.Error())
	}

项目监听消息

// rabbitMq消费
func startRabbitMQ() error {
	r, err := rabbitMQ.New(conf.AppConfig.RabbitMqUrl)
	if err != nil {
		conf.Log.Fatalf("New RabbitMQ Fatal:%s", err.Error())
		return err
	}
	r.RegisterConsumer("subscribe", rabbitMQ.TextMqConsumer)

	r.StartConsumer()
	return nil
}

func main() {
	g.Go(startApp)
	//g.Go(startRabbitMQ)
	if err := g.Wait(); err != nil {
		log.Fatal(err)
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值