你真的了解RPC吗?

44次阅读

共计 955 个字符,预计需要花费 3 分钟才能阅读完成。

现微服务盛行,服务之间通信大概就两种方式 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 div($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)->div(5)->get();

Api 实现:
你觉得 Api 应该怎么实现?
以上代码是我在设计 one 框架的一些思考?
如你喜欢请 star https://github.com/lizhichao/one
如其他观点,欢迎留言讨论。

正文完
 0