php异步可控并发执行耗时任务

记一次项目开发中遇到的问题以及解决方法:

问题:由于项目需定时执行一项非常耗时的任务,由于执行时间太长导致超时没有真正执行任务。

解决方法:使用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();
        }
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章