我用下面的函數笨,讓我的最新的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秒鐘才能執行。誰能告訴我爲什麼會發生這種情況?
我幾乎肯定它不是Twitter,因爲它發生在過去的兩天。谷歌搜索「curl_exec」我發現許多執行時間很慢,這個功能。另外它的本地運行速度很快(在我的MAC上),所以也許它與服務器有關。我能想到的唯一解決方法就是做一個cron作業並在本地存儲推文。 – 2010-10-05 10:33:33