# 远程调用
# 前言
Herosphp 支持自定义进程,做简单RPC非常容易。
# 安装
# 1. 新建文件 process/Rpc.php 编写rpc进程
<?php
namespace process;
use Workerman\Connection\TcpConnection;
class Rpc
{
public function onMessage(TcpConnection $connection, $data)
{
static $instances = [];
$data = json_decode($data, true);
$class = 'rpc\\service\\'.$data['class'];
$method = $data['method'];
$args = $data['args'];
if (!isset($instances[$class])) {
$instances[$class] = new $class; // 缓存类实例,避免重复初始化
}
$connection->send(call_user_func_array([$instances[$class], $method], $args));
}
}
# 2、打开config/process.php
,增加配置启动rpc进程
return [
'rpc' => [
'handler' => process\Rpc::class,
'listen' => 'text://0.0.0.0:8888', // 这里用了text协议,workerman内置协议,当然还可以是其他协议
'count' => 8, // 可以设置多进程
]
];
# 3.新建rpc/service/User.php
服务 (目录不存在自行创建)
<?php
namespace rpc\service;
class User
{
public function get($uid)
{
return json_encode([
'uid' => $uid,
'name' => 'tom'
]);
}
}
# 4.重启
# 调用
客户端调用
<?php
$client = stream_socket_client('tcp://127.0.0.1:8888');
$request = [
'class' => 'User',
'method' => 'get',
'args' => [100], // 100 是 $uid
];
fwrite($client, json_encode($request)."\n"); // text协议末尾有个换行符"\n"
$result = fgets($client, 10240000);
$result = json_decode($result, true);
var_export($result);
打印结果:
array (
'uid' => 100,
'name' => 'tom',
)