RabbitMQ 入门指南(六)

Remote Procedure Call (RPC)

Remote Procedure Call,即远程过程调用,简称 RPC,它是一种网络数据交互的协议规范,它让客户端能够像调用本地的函数一样调用远程服务端的函数。

多系统之间的内部数据交互,一般采用 RPC。

在 RabbitMQ 入门指南(二)中,我们学习了如何使用 Work Queue 将耗时的任务分配给多个 worker。

但是,如果我们需要调用远程服务器的方法并等待它的返回结果,该怎么处理?

这里,我们将使用 RabbitMQ 来构建一个十分简单的 RPC 系统(它包含一个客户端和一个可扩展的 RPC 服务端)。

Client interface

为了展示 RPC 服务如何使用,我们将创建一个简单的 client class。在该类中,有一个 call 方法,用于发送 RPC 请求,该方法会阻塞直到收到服务端的响应。

$fibonacci_rpc = new FibonacciRpcClient();
$response = $fibonacci_rpc->call(30);
echo ' [.] Got ', $response, "\n";

说明: 尽管 RPC 是非常常见的网络通信模式,但它却是饱受争议的。

回调队列

通常,在 RabbitMQ 上执行 RPC 是很容易的。客户端发送请求消息,服务器返回响应消息。为了接收响应,客户端在发送请求时需要指定 callback queue。

list($queue_name, ,) = $channel->queue_declare("", false, false, true, false);

$msg = new AMQPMessage(
    $payload,
    array('reply_to' => $queue_name)
);

$channel->basic_publish($msg, '', 'rpc_queue');

# ... then code to read a response message from the 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值