V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
tanszhe
V2EX  ›  程序员

对比 Restful Api 和 Rpc

  •  
  •   tanszhe · 2019-05-05 10:25:45 +08:00 · 3334 次点击
    这是一个创建于 1367 天前的主题,其中的信息可能已经有所发展或是发生改变。

    微服务之间通信主要有两种方式Restful ApiRpc,本文主要聊一聊他们的区别。

    这些列子是基于 one 的 (一个极简 . 高性能 . 松耦合 . 分布式框架 ) https://github.com/lizhichao/one 欢迎大家 star。

    列子一 文章的增删改查。

    Restful Api 实现:

    
    Router::get('/article/{id}','[email protected]');
    Router::post('/article','[email protected]');
    Router::put('/article/{id}','[email protected]');
    Router::delete('/article/{id}','[email protected]');
    
    

    然后在控制器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 应该怎么实现?

    6 条回复    2019-05-09 16:42:41 +08:00
    raptor
        1
    raptor  
       2019-05-05 10:48:35 +08:00
    php 是最好的语言,你开心就好。

    本质上 RESTful 也可以是一种 RPC 方式,看你怎么包装了。
    freedomshi
        2
    freedomshi  
       2019-05-05 14:20:43 +08:00
    Rpc 的范围有点大
    sagaxu
        3
    sagaxu  
       2019-05-05 14:34:31 +08:00 via Android
    但是 restful 其它语言可以拿来就用,用 curl 也能调用
    ruoxie
        4
    ruoxie  
       2019-05-05 15:13:48 +08:00 via Android
    消息队列也是一种微服务通讯方式
    siteshen
        5
    siteshen  
       2019-05-05 19:21:15 +08:00
    其实本文的核心是 GitHub 链接,楼上的关注点都错了。
    Evilk
        6
    Evilk  
       2019-05-09 16:42:41 +08:00
    别问,问就是 PHP
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   广告投放   ·   实用小工具   ·   1694 人在线   最高记录 5497   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 39ms · UTC 13:15 · PVG 21:15 · LAX 05:15 · JFK 08:15
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.