微服务之间通信主要有两种方式Restful Api
和Rpc
,本文主要聊一聊他们的区别。
这些列子是基于 one 的 (一个极简 . 高性能 . 松耦合 . 分布式框架 ) https://github.com/lizhichao/one 欢迎大家 star。
Restful Api
实现:
Router::get('/article/{id}','ArticleController@get');
Router::post('/article','ArticleController@create');
Router::put('/article/{id}','ArticleController@edit');
Router::delete('/article/{id}','ArticleController@delete');
然后在控制器ArticleController
调用模型实现对数据的操作。
// get
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();
Restful Api
实现:你觉得 Restful Api
应该怎么实现?
1
raptor 2019-05-05 10:48:35 +08:00
php 是最好的语言,你开心就好。
本质上 RESTful 也可以是一种 RPC 方式,看你怎么包装了。 |
2
freedomshi 2019-05-05 14:20:43 +08:00
Rpc 的范围有点大
|
3
sagaxu 2019-05-05 14:34:31 +08:00 via Android
但是 restful 其它语言可以拿来就用,用 curl 也能调用
|
4
ruoxie 2019-05-05 15:13:48 +08:00 via Android
消息队列也是一种微服务通讯方式
|
5
siteshen 2019-05-05 19:21:15 +08:00
其实本文的核心是 GitHub 链接,楼上的关注点都错了。
|
6
Evilk 2019-05-09 16:42:41 +08:00
别问,问就是 PHP
|