博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
你真的了解RPC吗?
阅读量:6933 次
发布时间:2019-06-27

本文共 1174 字,大约阅读时间需要 3 分钟。

现微服务盛行,服务之间通信大概就两种方式ApiRpc

下面两个列子来让你了解ApiRpc的区别。

列子一 文章的增删改查。

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

如其他观点,欢迎留言讨论。

转载地址:http://hnwnl.baihongyu.com/

你可能感兴趣的文章
实战Jenkins+SVN+tomcat持续集成发布
查看>>
为Nginx制作404 403 500等错误页面
查看>>
ognl 表达式常用表达式语言
查看>>
Nginx/LVS/HAProxy 负载均衡软件的优缺点详解
查看>>
Oracle导表语句
查看>>
ORA-28001: 口令已经失效
查看>>
我的友情链接
查看>>
现代软件工程 结对编程 (I) 三维棋类游戏
查看>>
Provisioning Services 7.6 入门到精通系列之九:创建和配置目标设备
查看>>
ospf专题二:虚链路
查看>>
《卫生信息基本数据集编制规范》等23项行业标准的通告
查看>>
我的友情链接
查看>>
前端优化的小结
查看>>
对实体类的所有String类型的成员变量值trim
查看>>
rsync的部署
查看>>
RHEL-5搭建SSH服务器
查看>>
Android资源命名规范
查看>>
盘点路由协议之RIP协议及IGRP协议
查看>>
多DHCP服务器的作用域 及备用DHCP服务器(一)
查看>>
CSS布局-顺口溜
查看>>