您的位置:首页 > 其它

【Yar】Yar异步调用的超时时间问题以及解决方案

2016-11-04 19:45 399 查看

问题

由于具体业务功能需要,需要采用并行异步的方式调用方法。

但是业务上要求每个被调用的方法的执行时间最多60秒,这就导致采用Yar的调用一直是timeout.

Yar_Concurrent_Client::loop(): select timeout 5000ms reached

解决方案

1.修改配置文件

Yar扩展的配置项如下

yar.packager php

yar.debug

yar.connect_timeout

yar.timeout

yar.expose_info

所以,采用
ini_set()
方法实现对php.ini的动态修改,实现修改
yar.timeout
,完成超时时间的配置问题。

ini_set("yar.timeout",60000);


2.方法参数设置

实际上这个方法在事例代码中是存在。

Yar_Concurrent_Client::call(“http://host/api/“, “some_method”, array(“parameters”), “callback”, NULL, array(YAR_OPT_TIMEOUT=>1));

在这里配置第五个参数,设置
YAR_OPT_TIMEOUT
.

我在这里遇到的问题是,callback函数一直找不到,所以采用的是第一个方法。

参看资料

http://php.net/manual/zh/yar-concurrent-client.call.php

http://www.laruence.com/2012/09/15/2779.html

Laruence本人
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: