golang使用rabbitmq(一)工作队列

栏目: Redis · 发布时间: 5年前

内容简介:版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/lastsweetop/article/details/91363644

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/lastsweetop/article/details/91363644

在helloworld那一章讲了一个简单的一个生产者一个消费者的模型,但生产系统中很多时候是多个生产者或者多个消费者同时处理的。

body := bodyFrom(os.Args)
	err = ch.Publish("", q.Name, false, false, amqp.Publishing{
		DeliveryMode: amqp.Persistent,
		ContentType:  "text/plain",
		Body:         []byte(body),
	})

bodyFrom

func bodyFrom(args []string) string {
	if len(args) > 1 {
		return strings.Join(args[1:], " ")
	}
	return "default"
}
msgs, err := ch.Consume(q.Name, "", true, false, false, false, nil)
	failOnError(err, "Failed to register a consumer")


	go func() {
		for msg := range msgs {
			log.Printf("Received a message: %s", msg.Body)
			dotCount := bytes.Count(msg.Body, []byte("."))
			t := time.Duration(dotCount)
			time.Sleep(t * time.Second)
			log.Printf("Done")
		}
	}()

默认情况下消息会循环分发到消费者

消息ack

当消费者的 autoack 为true时,一旦收到消息就会直接把该消息设置为删除状态,如果消息的处理时间之内,消费者挂掉了那么这条消息就会丢失掉。

rabbitmq支持消息ack机制,将autoack设为false,当处理完毕再手动触发ack操作。如果处理消息的过程中挂掉了,那么这条消息就会分发给其他都消费者。

msgs, err := ch.Consume(q.Name, "", false, false, false, false, nil)
	failOnError(err, "Failed to register a consumer")


	go func() {
		for msg := range msgs {
			log.Printf("Received a message: %s", msg.Body)
			dotCount := bytes.Count(msg.Body, []byte("."))
			t := time.Duration(dotCount)
			time.Sleep(t * time.Second)
			log.Printf("Done")
			msg.Ack(false)
		}
	}()

消息持久性

之前说的是消费者挂掉不会丢失消息的解决方法,那么如果mq挂掉呢,如果保证mq挂掉都不会丢失消息,那么就是消息持久性做到事情。

消息持久性分为两步

队列的持久性

将队列设为持久的,当mq重启的时候不会丢失队列

q, err := ch.QueueDeclare("workQueue", true, false, false, false, nil)

消息的持久性

发布消息时,设置消息为持久的

err = ch.Publish("", q.Name, false, false, amqp.Publishing{
		DeliveryMode: amqp.Persistent,
		ContentType:  "text/plain",
		Body:         []byte(body),
	})

公平分配

循环分配方式只能做到平均分配,每个消费者一个一次分配,但是平均不一定就是公平,比如有的消费者所在的服务器资源较差的情况下,平均肯定是不合理的,为了做到公平那么使用如下设置即可

err = ch.Qos(1, 0, false)

这段代码的意思是最多同时处理一个,多了先别发给我。


以上所述就是小编给大家介绍的《golang使用rabbitmq(一)工作队列》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Artificial Intelligence

Artificial Intelligence

Stuart Russell、Peter Norvig / Pearson / 2009-12-11 / USD 195.00

The long-anticipated revision of this #1 selling book offers the most comprehensive, state of the art introduction to the theory and practice of artificial intelligence for modern applications. Intell......一起来看看 《Artificial Intelligence》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器