對比Restful Api和Rpc

探索者1492569170005發表於2019-05-05

微服務之間通訊主要有兩種方式Restful ApiRpc,本文主要聊一聊他們的區別。

這些列子是基於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 應該怎麼實現?

相關文章