curl_multi_exec在Mac OS X上失败

时间:2013-11-15 10:54:28

标签: php macos curl curl-multi

我正在尝试从我的Mac OS X(Mavericks)下的php.net运行这段简单的代码来尝试cURL multi exec功能:

<?php
    // create both cURL resources
    $ch1 = curl_init();
    $ch2 = curl_init();

    // set URL and other appropriate options
    curl_setopt($ch1, CURLOPT_URL, "http://lxr.php.net/");
    curl_setopt($ch1, CURLOPT_HEADER, 0);
    curl_setopt($ch2, CURLOPT_URL, "http://www.php.net/");
    curl_setopt($ch2, CURLOPT_HEADER, 0);

    //create the multiple cURL handle
    $mh = curl_multi_init();

    //add the two handles
    curl_multi_add_handle($mh,$ch1);
    curl_multi_add_handle($mh,$ch2);

    $active = null;
    //execute the handles
    do {
        $mrc = curl_multi_exec($mh, $active);
    } while ($mrc == CURLM_CALL_MULTI_PERFORM);

    while ($active && $mrc == CURLM_OK) {
        if (curl_multi_select($mh) != -1) {
            do {
                $mrc = curl_multi_exec($mh, $active);
            } while ($mrc == CURLM_CALL_MULTI_PERFORM);
        }
    }

    //close the handles
    curl_multi_remove_handle($mh, $ch1);
    curl_multi_remove_handle($mh, $ch2);
    curl_multi_close($mh);

    ?>

这不起作用,因为我得到的唯一输出是:

  

PHP致命错误:

中超出了30秒的最长执行时间

这是我的环境:Mac OS X 10.9,PHP 5.4.17,Apache 2.2.24。

安装cUrl,因为我的常规卷曲“单个”请求工作得很好。

我认为这是Mac OS的一个问题,但我找不到任何修复方法。你有什么想法吗?

编辑:我在Linux服务器上尝试了相同的代码,一切正常。

1 个答案:

答案 0 :(得分:2)

在php 5.3.18+上,请注意curl_multi_select()可能永远返回-1,直到你调用curl_multi_exec()。

试试这个:

while ($this->active && $mrc == CURLM_OK) 
{   
   // add this line
   while (curl_multi_exec($this->mh, $this->active) === CURLM_CALL_MULTI_PERFORM);

   if (curl_multi_select($this->mh) != -1) 
   {   
       do {
           $mrc = curl_multi_exec($this->mh, $this->active);
           if ($mrc == CURLM_OK)
           {   
               while($info = curl_multi_info_read($this->mh))
               {   
                   $this->process($info);
               }        
           }   
       } while ($mrc == CURLM_CALL_MULTI_PERFORM);
   }   
} 

有关详细信息,请参阅https://bugs.php.net/bug.php?id=63411http://marchtea.com/?p=109