首页 > 后端开发 > php教程 > 服务间通信RPC的详细介绍

服务间通信RPC的详细介绍

不言
发布: 2023-04-04 15:52:01
转载
4035 人浏览过

本篇文章给大家带来的内容是关于服务间通信RPC的详细介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

现微服务盛行,服务之间通信大概就两种方式Api和Rpc。

下面两个列子来让你了解Api和Rpc的区别。

列子一 文章的增删改查。

Api 实现:

Router::get('/article/{id}','ArticleController@get');
Router::post('/article','ArticleController@create');
Router::put('/article/{id}','ArticleController@edit');
Router::delete('/article/{id}','ArticleController@delete');
登录后复制

然后在控制器Article调用模型

return Article::find($id)->toArray();
登录后复制

Rpc 实现

RpcServer::add('Article');
登录后复制

没错就一行代码

列子二 计算器

假如机器A上面一个计算器 Counter,以Rpc的方式提供给其他机器使用.

计算器Counter代码

class Counter
{

    private $i = 0;

    public function __construct($i = 0)
    {
        $this->i = $i;
    }

    // 加法
    public function add($v)
    {
        $this->i += $v;
        return $this;
    }

    // 减法
    public function sub($v)
    {
        $this->i -= $v;
        return $this;
    }

    // 乘法
    public function mul($v)
    {
        $this->i *= $v;
        return $this;
    }

    // 除法
    public function p($v)
    {
        $this->i /= $v;
        return $this;
    }

    // 获取结果
    public function get()
    {
        return $this->i;
    }
}
登录后复制

Rpc 实现

RpcServer::add('Counter');
登录后复制

Rpc客户端调用

$c = new ClientCounter(10);
echo $c->add(3)->mul(2)->sub(10)->p(5)->get();
登录后复制

以上是服务间通信RPC的详细介绍的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:segmentfault.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板