1、老的curl訪問方式以及耗時統(tǒng)計
<?phpfunction curl_fetch($url, $timeout=3){    $ch = curl_init();    curl_setopt($ch, CURLOPT_URL, $url);    curl_setopt($ch, CURLOPT_TIMEOUT, $timeout);    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);    $data = curl_exec($ch);    $errno = curl_errno($ch);    if ($errno>0) {        $data = false;    }    curl_close($ch);    return $data;}function microtime_float(){   list($usec, $sec) = explode(" ", microtime());   return ((float)$usec + (float)$sec);}$url_arr=array(     "taobao"=>"http://www.taobao.com",     "sohu"=>"http://www.sohu.com",     "lai18"=>"http://www.lai18.com",);$time_start = microtime_float();$data=array();foreach ($url_arr as $key=>$val){     $data[$key]=curl_fetch($val);}$time_end = microtime_float();$time = $time_end - $time_start;echo "耗時:{$time}";?><?phpfunction curl_multi_fetch($urlarr=array()){    $result=$res=$ch=array();    $nch = 0;    $mh = curl_multi_init();    foreach ($urlarr as $nk => $url) {        $timeout=2;        $ch[$nch] = curl_init();        curl_setopt_array($ch[$nch], array(            CURLOPT_URL => $url,            CURLOPT_HEADER => false,            CURLOPT_RETURNTRANSFER => true,            CURLOPT_TIMEOUT => $timeout,        ));        curl_multi_add_handle($mh, $ch[$nch]);        ++$nch;    }    /* wait for performing request */    do {        $mrc = curl_multi_exec($mh, $running);    } while (CURLM_CALL_MULTI_PERFORM == $mrc);     while ($running && $mrc == CURLM_OK) {        // wait for network        if (curl_multi_select($mh, 0.5) > -1) {            // pull in new data;            do {                $mrc = curl_multi_exec($mh, $running);            } while (CURLM_CALL_MULTI_PERFORM == $mrc);        }    }     if ($mrc != CURLM_OK) {        error_log("CURL Data Error");    }     /* get data */    $nch = 0;    foreach ($urlarr as $moudle=>$node) {        if (($err = curl_error($ch[$nch])) == '') {            $res[$nch]=curl_multi_getcontent($ch[$nch]);            $result[$moudle]=$res[$nch];        }        else        {            error_log("curl error");        }        curl_multi_remove_handle($mh,$ch[$nch]);        curl_close($ch[$nch]);        ++$nch;    }    curl_multi_close($mh);    return  $result;}$url_arr=array(     "taobao"=>"http://www.taobao.com",     "sohu"=>"http://www.sohu.com",     "lai18"=>"http://www.lai18.com",     );function microtime_float(){   list($usec, $sec) = explode(" ", microtime());   return ((float)$usec + (float)$sec);}$time_start = microtime_float();$data=curl_multi_fetch($url_arr);$time_end = microtime_float();$time = $time_end - $time_start; echo "耗時:{$time}";?>耗時:0.316秒 帥氣吧整個頁面訪問后端接口的時間節(jié)省了一半
《CURL技術(shù)知識教程》系列技術(shù)文章整理收藏http://blog.csdn.net/hello_katty/article/details/45557423
PHP編程鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。
新聞熱點
疑難解答
圖片精選