Php curl错误:在DNS缓存中找不到主机名

时间:2015-06-19 10:12:18

标签: php apache curl dns bind9

我的php脚本中有一个curl请求有问题我已经上传到我的专用网络服务器上了。我知道这个卷曲请求工作正常,因为我已经在我的本地机器上测试过了。我认为这个问题来自我的apache配置或我的DNS。但我不确定。

当我使用curl_setopt($ch, CURLOPT_VERBOSE, true);时,我的专用服务器上的test_curlog.log中出现以下错误消息:

* Rebuilt URL to: http://example.org/
* Hostname was NOT found in DNS cache
* Hostname was NOT found in DNS cache

以下是我使用的代码:

<?php
var_dump("MULTI CURL REQUEST");
$error_curl_log = __DIR__ . '/../../../../web/test_curlog.log';
$fp = fopen($error_curl_log, 'a+');

// Création des ressources cURL
$ch2 = curl_init();
$ch3 = curl_init();

// Définit l'URL ainsi que d'autres options

curl_setopt($ch2, CURLOPT_URL, "http://example.org");
curl_setopt($ch2, CURLOPT_HEADER, 0);
curl_setopt($ch2, CURLOPT_VERBOSE, true); //For debug
curl_setopt($ch2, CURLOPT_STDERR, $fp);

curl_setopt($ch3, CURLOPT_URL, "https://www.googleapis.com/language/translate/v2?key=INSERT-YOUR-KEY&source=en&target=de&q=Hello%20world");
curl_setopt($ch3, CURLOPT_HEADER, 0);
curl_setopt($ch3, CURLOPT_VERBOSE, true); //For debug
curl_setopt($ch3, CURLOPT_STDERR, $fp);

// Création du gestionnaire multiple
$mh = curl_multi_init();

// Ajoute les deux gestionnaires
curl_multi_add_handle($mh, $ch2);
curl_multi_add_handle($mh, $ch3);

$active = null;
// Exécute le gestionnaire
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);
    }
}
// Ferme les gestionnaires
curl_multi_remove_handle($mh, $ch2);
curl_multi_remove_handle($mh, $ch3);
curl_multi_close($mh);
die;

在我的本地计算机上,我在浏览器上收到此回复: enter image description here

所以我应该在我的专用服务器上获得相同但我收到此错误:Maximum execution time of 60 seconds exceeded因为curl请求似乎找不到url。

任何帮助都将受到赞赏。

1 个答案:

答案 0 :(得分:0)

最后,我找到了解决方案。它包括在while循环中添加这个条件:

$mrc === CURLM_CALL_MULTI_PERFORM || $active

像这样:

$active = null;
// Exécute le gestionnaire
do {
    $mrc = curl_multi_exec($mh, $active);
    // Vérification des erreurs
    if($mrc > 0) {
        // Affiche le message d'erreur
        echo "ERREUR !\n " . curl_multi_strerror($mrc);
    }
} while ($mrc === CURLM_CALL_MULTI_PERFORM || $active);

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

我不知道为什么但它有效