php 常用rpc框架,php的轻量级rpc框架yar

php的轻量级rpc框架yar

目的:类方法的远程调用,也就是一个rpc请求。

RPC本质上也是一个网络请求,既然是请求,对于效率来说,就需要考虑了。yar是基于http来做的。

使用场景:多个项目共享model

总的来说这种调用代价挺好的,因为有网络开销。

其实咱们也可以采用其他方式替代

使用的时候注意安全问题。比如只支持内网调用。pecl install yar

yar的特点:能够实现多个请求并发。

如何使用:本地的server说明:

server url地址  http://other.program.php/php-library/source/yar/model/yar_server.php

sever代码:

$server = new Yar_Server(new MyYarServer());

$server->handle();

client url地址:http://other.program.php/php-library/source/yar/pc_yar.php

client代码:

$pc_client = new Yar_Client($server_url);

$id = 12;

//就像调用本地方法一样

$pc_client->SetOpt(YAR_OPT_CONNECT_TIMEOUT, 1000);

$res = $pc_client->getData($id);

print_r($res);

client的并行调用,是采用curl的方式实现的

function callback($retval, $callinfo) {

var_dump($retval,$callinfo);

}

function error_callback($type, $error, $callinfo) {

error_log($error);

}

$server_url = "http://other.program.php/php-library/source/yar/model/yar_server.php";

Yar_Concurrent_Client::call($server_url, "getData", array("1"), "callback");

Yar_Concurrent_Client::call($server_url, "getData", array("2"));// if the callback is not specificed,

// callback in loop will be used

Yar_Concurrent_Client::call($server_url, "getData", array("3"), "callback", NULL, array(YAR_OPT_PACKAGER => "json"));

//this server accept json packager

Yar_Concurrent_Client::call($server_url, "getData", array("11"), "callback", NULL, array(YAR_OPT_TIMEOUT=>1));

Yar_Concurrent_Client::loop("callback","error_callback");

优点:这些调用通过扩展的c代码实现,简单高效

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值