jjzjj

Rabbitmq

全部标签

go - 暂停 RabbitMQ 消费者

我正在使用Go为RabbitMQ编写消费者,它必须暂停消息消费一段时间,然后恢复以再次使用队列中的消息。在阅读文档时https://godoc.org/github.com/streadway/amqp我无法确定我需要在我的代码中实现的机制。这有可能吗?有例子吗?我的代码片段:rabbitMQMessages,err=ch.Consume("TestQ","testConsumer",false,true,false,false,nil,)failOnError(err,"Failedtoregisteraconsumer")forever:=make(chanbool)gofunc(

go - 如何使用Golang组织异步消息发布到RabbitMQ?

我正在尝试使用此流行的RabbitMQ软件包在RabbitMQ中组织异步消息发布:https://godoc.org/github.com/streadway/amqp该库声称支持异步发布。但是我找不到一个例子。我也找不到任何接受回调函数作为输入的函数。有人可以帮忙在Golang上发布异步发布的简单示例吗? 最佳答案 我找到了用于此任务的客户端库。https://github.com/streadway/amqp默认情况下,它实现了异步消息传递。可能对某人有用。 关于go-如何使用Gol

go - RabbitMQ 消费者性能 - 预取与并发

我有一个Go应用程序处理来自单个RabbitMQ队列的事件。我用github.com/streadway/amqpRabbitMQ客户端库。Go应用程序在大约2-3秒内处理每条消息。如果我从内存中输入消息,则可以并行处理~1000条甚至更多消息。但是,不幸的是,RabbitMQ的性能更差。所以,我想更快地使用队列中的消息。因此,问题是:如何使用github.com/streadway/amqp以最有效的方式使用消息?据我了解,有两种方法:设置高预取https://godoc.org/github.com/streadway/amqp#Channel.Qos.使用单个消费者协程示例代码:

json - 如何正确反序列化包含来自 JSON 的顶级数组的 RabbitMQ 消息

我尝试这样做:casemessage:=它工作了一些迭代,而不是因错误解码:JSON输入意外结束和message.Body==nil而失败。但是一切正常,如果JSON不是对象列表([{...},{...},...]而只是单个对象{...}我试过了RmqMessagesstruct{Messages[]RmqMessage}rmqMessages:=RmqMessages{}err:=json.Unmarshal(message.Body,&rmqMessages.Messages)同样的结果我做错了什么? 最佳答案 错误是在ack循

python - RabbitMQ 消息丢失

我使用Pythonapi向RabbitMQ中插入消息,然后使用goapi从RabbitMQ获取消息。关键1:RabbitMQACK因性能原因设置为false。我通过pythonapi向RabbitMQ插入了大约超过100,000,000条消息,但是当我使用goapi获取消息,我发现消息的插入数不等于获取数。插入操作和获取操作是并发的。关键2:丢失消息率不超过1,000,000%1.插入Action有日志,pythonapi显示所有插入消息成功。getaction有log,goapi显示所有getmessage成功。但数量并不相等。问题1:我不知道如何找到消息丢失的地方,谁能给我一个建议

go - RabbitMQ 循环法

我正在尝试构建一个系统,其中主服务创建一堆消息并根据路由键将它们路由到正确的队列。我有那个工作,消息正在工作人员/从属方使用。但是,我希望工作人员只从队列中取出一条消息,而不是将所有15条消息都放入队列中。我在看这个https://github.com/streadway/amqp/blob/master/channel.go#L616但是我不确定如何设置它,所以只记录了一个事件。有什么想法吗? 最佳答案 免责声明:我没有使用过GoAMQP客户端,但AMQP协议(protocol)语义应该在客户端实现中是通用的,所以我会试一试。您已

go - 使用 Go RabbitMQ streadway/amqp 驱动程序时无法从函数返回 *amqp.Channel

我正在尝试使用streadway/amqp连接到RabbitMQ总线Go的驱动程序。我正在处理重新连接例程,为此,我有一个rabbitMQConsume函数调用rabbitMQConnect函数。funcrabbitMQConnect(cfgobjects.GlobalConfig)(*amqp.Connection,*amqp.Channel,error){rabbitConfig:=amqp.Config{Vhost:cfg.RabbitVHost,Heartbeat:5,}//OpenconnectiontoRabbiturl:=fmt.Sprintf("amqp://"+cfg

for-loop - Golang 中的事件驱动模型

我正在阅读RabbitMQtutorial并看到以下代码:forever:=make(chanbool)gofunc(){ford:=rangemsgs{log.Printf("Receivedamessage:%s",d.Body)}}()log.Printf("[*]Waitingformessages.ToexitpressCTRL+C")我感兴趣的是ford:=rangemsgs。这个for循环是如何处理事件的?例如。在应用程序启动时,msgs队列缓冲区中只有一条消息。问题:它将如何处理下一个事件?经过一些playingaround使用这段代码,我发现它可能会停留在log.Pr

go - 如何确保消息平均发送给所有消费者

在我们公司,我们用Go构建了一个推送服务,我们把它放在四台机器上以保证传输速度,当我们需要发送通知时,我们将消息发送到rabbitMQ,然后推送服务会从队列中获取消息,但有时我们发现只有一台机器收到消息。这里是rabbitMQ消费者的配置:msgs,err:=ch.Consume(q.Name,//queueconsumerTag,//consumertrue,//auto-ackfalse,//exclusivefalse,//no-localfalse,//no-waitnil,//args)我应该如何设置配置以确保每个消费者获得相同数量的消息? 最佳答

macos - RabbitMQ Go 教程日志.Printf 无法写入磁盘文件?

我正在通过go学习RabbitMQ教程。这是链接:https://www.rabbitmq.com/tutorials/tutorial-four-go.html当我运行以下命令将消息记录到文件时:gorunreceive_logs_direct.gowarningerror>logs_from_rabbit.log但是logs_from_rabbit.log文件仍然是空的。这是怎么回事? 最佳答案 您的重定向似乎缺少标准错误输出中的日志。尝试:gorunreceive_logs_direct.gowarningerror>stdo