2012-07-30 75 views
2

我有一个用php编写的下载网站,使用curl从远程服务器上下载,但事情是httpd连接没有终止,它们仍然处于睡眠模式,这是我的服务器资源被查杀,这里是顶级输出许多睡眠httpd连接

 
top - 20:55:36 up 4 days, 13:41, 1 user, load average: 1.99, 5.73, 
10.47 Tasks: 2207 total, 5 running, 2202 sleeping, 0 stopped, 0 zombie Cpu(s): 24.1%us, 1.5%sy, 0.0%ni, 73.3%id, 0.0%wa, 0.0%hi, 1.1%si, 
0.0%st Mem: 4045976k total, 4000712k used, 45264k free, 1448k buffers Swap: 8385920k total, 2353584k used, 6032336k free, 30336k cached 

我跟踪使用此strace -p 22254 -s 80 -o /tmp/debug.lighttpd.txt一个PID我得到这个输出,我不知道,但它似乎是投票和投票

clock_gettime(CLOCK_MONOTONIC, {10396, 471413333}) = 0 
poll([{fd=24, events=POLLOUT}], 1, 725) = 0 (Timeout) 
clock_gettime(CLOCK_MONOTONIC, {10397, 196905333}) = 0 
clock_gettime(CLOCK_MONOTONIC, {10397, 196955333}) = 0 
poll([{fd=24, events=POLLOUT}], 1, 1000) = 0 (Timeout) 
clock_gettime(CLOCK_MONOTONIC, {10398, 197890333}) = 0 
clock_gettime(CLOCK_MONOTONIC, {10398, 197937333}) = 0 
poll([{fd=24, events=POLLOUT}], 1, 1000) = 0 (Timeout) 

在那里我失踪或任何HTTP头无论如何要终止这些连接,任何想法?

这里是我使用的PHP代码,这是其中的重要组成部分它

header('Content-Disposition: filename='.$fileName); 
header("Content-Type: application/octet-stream\n"); 
header("Connection: close\n"); 
header("Accept-Ranges: bytes"); 
header("Content-Range: bytes 0-$size2/$size"); 
header("Content-Length: ".$size); 

while($start_range <= $end_range) { 
if (connection_status()!=0) return(false); 
if(($start_range + 999999) > $end_range) $range = $start_range.'-'; 
else $range = $start_range.'-'.($start_range + 999999); 
$ch = curl_init(); 
curl_setopt($ch, CURLOPT_URL, $fileLocation); 
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); 
if ($cookie != false) curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie); 
if ($refurl != false) curl_setopt($ch, CURLOPT_REFERER, $refurl); 
curl_setopt($ch, CURLOPT_RANGE,$range); 
curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.1) Gecko/20061204 Firefox/2.0.0.1'); 
curl_exec($ch); 
curl_close($ch); 
$start_range +=1000000; 

flush(); 
ob_flush(); 
ob_end_flush(); 
} 
+0

我们如何诊断这个问题没有任何PHP代码?堆栈跟踪几乎没有用,甚至没有。 – Steven 2012-07-30 00:53:11

+0

@JaredFarrish:我很抱歉,我将从现在开始回答 – EGN 2012-07-30 00:59:13

+0

@Steven:添加了PHP代码 – EGN 2012-07-30 00:59:27

回答

0

所以问题是与HTTP头保持活跃,连接保持活跃造成的麻烦,在这里是我如何修复它。

我没有发起和关闭每次卷曲,而是一个卷曲发起,我发送http头定义保持活动和保持活动时间。这解决了我的问题

$ch = curl_init(); 
while($start_range <= $end_range) { 
    if (connection_status()!=0) return(false); 
    if(($start_range + 999999) > $end_range) $range = $start_range.'-'; 
    else $range = $start_range.'-'.($start_range + 999999); 
    curl_setopt($ch, CURLOPT_URL, $fileLocation); 
    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
    curl_setopt($ch, CURLOPT_HTTPHEADER, array(
    'Connection: Keep-Alive', 
    'Keep-Alive: 300', 
    'Cache-Control: no-cache' 
    )); 
    if ($cookie != false) curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie); 
    if ($refurl != false) curl_setopt($ch, CURLOPT_REFERER, $refurl); 
    curl_setopt($ch, CURLOPT_RANGE,$range); 
    curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.1) Gecko/20061204 Firefox/2.0.0.1'); 
    $content = curl_exec($ch); 
    echo $content; 
    unset($content); 
    $start_range +=1000000;  
    flush(); 
    ob_flush(); 
} 
curl_close($ch); 
+0

为什么你需要保持活力?为什么不设置CURLOPT_CONNECTTIMEOUT? – Steven 2012-07-31 19:33:19