记一次项目开发中遇到的问题以及解决方法:
问题:由于项目需定时执行一项非常耗时的任务,由于执行时间太长导致超时没有真正执行任务。
解决方法:使用curl的curl_multi_*
族函数实现简单的并发.。参考网址
1,引入参考网址的Curl_request类和Curl类;
2,我自己的关键调用代码如下,相当于分页查询数据库并执行:
public function index() {
$count = Db::name('mytable')
->field('id')
->where('status', 'between', [0,1])
->union('SELECT id FROM mytable WHERE status BETWEEN 4 AND 6')
->count();
//每次取数据条数
$limit = $step = 2000;
//计算总页数
$pages = ceil($count/$step);
if ($pages > 0) {
$curl = new Curl();
$url = $this->request->domain() . '/task/express_info_task/execute';
for ($page = 1; $page <= $pages; $page++) {
$request = new CurlRequest($url . '?page=' . $page . '&limit=' . $limit);
$curl->add($request);
}
$curl->execute();
echo $curl->display_errors();
}
}