golang使用rabbitmq(六)RPC

本文介绍如何在Golang中利用RabbitMQ实现RPC(远程过程调用)功能。通过设置特定属性,调用方在发送指令时指定回复队列,然后阻塞等待从该队列接收处理结果。被调用方处理完消息后,将结果直接写入回复队列,若需要复用回复队列,可以使用标识进行区分。
摘要由CSDN通过智能技术生成

之前的章节都是在说一方发指令,另一方执行这种情况,指令发送者不关系指令的完成情况,或者不需要阻塞去获得结果,结果异步通知。

但很多时候是需要阻塞得去获得执行结果的,比如http的请求。

在rabbitmq使用RPC的关键就是ReplyTo属性

err = ch.ExchangeDeclare("rpc_topic", amqp.ExchangeTopic, true, false, false, false, nil)
	failOnError(err, "Failed to declare a exchange")

	q, err := ch.QueueDeclare("", false, false, true, false, nil)
	failOnError(err, "Failed to declare a queue")

	msgs, err := ch.Consume(q.Name, "", true, false, false, false, nil)
	failOnError
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值