栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

rabbitmq——持久化消息

rabbitmq——持久化消息

使用rabbitmq做持久化消息,我们有两种方式。

使用自动确认机制,如果使用这种机制,消费者接收到消息之后自动确认,但是如果接收到消息之后,服务卡顿,就会导致这条消息不会重新发送给其他或者重启之后的消费者所在的服务器。导致间接性消息丢失。使用手动确认机制,当消息接收到之后,不要立即确认收到,而是先处理,处理之后,再确认这条消息。

product.go

que , err := c.QueueDeclare("hello-test" , false , false , false , false , nil)
if err != nil {
	fmt.Println(err)
	return
}
fmt.Print(err)
_ = c.Publish("" , que.Name, false , false , amqp.Publishing{
	Body: []byte("test hello"),
})

consumer.go

	qu , err := c.QueueDeclare("hello-test" , false , false , false , false , nil)
	fmt.Println(err)
	//err = c.QueueBind(qu.Name , "info" , "dir" , false ,nil)
	fmt.Println(err)
	msg , err := c.Consume(qu.Name ,"" , false , false , false , false , nil)
	fmt.Println(err)
	for d := range msg {
		fmt.Println(string(d.Body))
		d.Ack(false)
	}

注意:在consumer.go中,将消息体输出之后再确认到接收,那么这里传递true和传递false有什么区别?

如果传递false,则只会确认当前消息体的接收,如果为true,则确认包括当前消息体在内的之前的消息都确认收到。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/753459.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号