微服務之間通訊主要有兩種方式Restful Api
和Rpc
,本文主要聊一聊他們的區別。
這些列子是基於one的 (一個極簡 . 高效能 . 鬆耦合 . 分散式框架 ) github.com/lizhichao/o… 歡迎大家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
應該怎麼實現?