2010-10-05 73 views
2

我用下面的函數笨,讓我的最新的tweet:PHP函數curl_exec()減慢我的劇本

function tweet($id) { 

     $c = curl_init(); 
     curl_setopt($c, CURLOPT_URL, "http://twitter.com/statuses/user_timeline/".$id.".xml?count=1"); 

     curl_setopt($c, CURLOPT_RETURNTRANSFER, 1); 

     //Benchmark starts here 
     $src = curl_exec($c); 
     //Benchmark ends here 

     curl_close($c); 

     preg_match('/<text>(.*)<\/text>/', $src, $t); 
     $data['tweet'] = htmlentities($t[1]); 
     preg_match('/<created_at>(.*)<\/created_at>/', $src, $c); 
     $created = $c[1]; 

     // explode $created so we can process it 
     $created_array = explode(' ',$created); 
     $time = $created_array[3]; 
     $time_array = explode(':',$time); 
     $format = '%b/%d/%Y %H:%M'; 
     $date_to_format = $created_array[1].'/'.$created_array[2].'/'.$created_array[5].' '.$time_array[0].':'.$time_array[1]; 
     $date_time = strptime($date_to_format,$format); 
     $created_timestamp = mktime($date_time['tm_hour'], $date_time['tm_min'], 0, $date_time['tm_mon']+1, $date_time['tm_mday'], $date_time['tm_year']+1900); 
     $time_diff = time() - $created_timestamp; 

     $data['time'] = time_since($time_diff); 

     return $data; 

    } 

我使用Benchmark類CI的看出爲什麼網站需要很長時間來響應,我發現該行

$src = curl_exec($c); 

需要超過5秒鐘才能執行。誰能告訴我爲什麼會發生這種情況?

回答

1

我剛剛在我的機器上測試了您的代碼(僅限於curl請求)並且沒有任何問題...它快速檢索數據:349ms。

難道你的網絡有問題嗎?或者,也許Tweeter在測試您的請求時有一段時間正確?上次我嘗試使用Twitter API時,整個網站都停止了,所以也許他們也有問題。

祝你好運

+1

我幾乎肯定它不是Twitter,因爲它發生在過去的兩天。谷歌搜索「curl_exec」我發現許多執行時間很慢,這個功能。另外它的本地運行速度很快(在我的MAC上),所以也許它與服務器有關。我能想到的唯一解決方法就是做一個cron作業並在本地存儲推文。 – 2010-10-05 10:33:33