# 远程调用

# 前言

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',
)
上次更新: 10/27/2022, 11:18:25 AM