操作在35007毫秒后超时,收到0字节

时间:2017-04-06 04:31:32

标签: php nginx windows-7

我在Windows 7上安装了nginx1.10和php5.6,但是我发现当我访问该页面时,它无法向使用相同监听端口的同一个脚本发出curl请求。

http://localhost/a.php中有一个卷曲请求,它向http://localhost/phpinfo.php发出卷曲请求,但错误得到Error:Operation timed out after 35007 milliseconds with 0 bytes received

server {
    listen 80;
    server_name localhost;
    root d:/localhost;
    index index.html index.htm index.php;
    autoindex on;
    autoindex_localtime on;

    location ~ \.php$ {
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        include        fastcgi_params;
    }
}




http://localhost/a.php


<?php
function makeRequest($url, $params, $method = 'GET')
{
    $ch = curl_init();
    if ($method == 'GET') {
        $url .= '?' . http_build_query($params);
    } else {
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $params);
    }

    if (substr($url, 0, 6) == 'https:') {
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
    }
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
    curl_setopt($ch, CURLOPT_USERAGENT, 'ApiClient/v1.0');
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 30);
    curl_setopt($ch, CURLOPT_TIMEOUT, 35);


    $result = curl_exec($ch);
    $info = curl_getinfo($ch);
    $error = curl_error($ch);

    curl_close($ch);
    print_r($info);
    var_dump($error);
    return $result;
}


$url = 'http://localhost/phpinfo.php';
makeRequest($url, []);

输出:

Array
(
    [url] => http://localhost/phpinfo.php?
    [content_type] => 
    [http_code] => 0
    [header_size] => 0
    [request_size] => 96
    [filetime] => -1
    [ssl_verify_result] => 0
    [redirect_count] => 0
    [total_time] => 35.007
    [namelookup_time] => 0.016
    [connect_time] => 0.219
    [pretransfer_time] => 0.219
    [size_upload] => 0
    [size_download] => 0
    [speed_download] => 0
    [speed_upload] => 0
    [download_content_length] => -1
    [upload_content_length] => -1
    [starttransfer_time] => 0
    [redirect_time] => 0
    [redirect_url] => 
    [primary_ip] => 127.0.0.1
    [certinfo] => Array
        (
        )

    [primary_port] => 80
    [local_ip] => 127.0.0.1
    [local_port] => 55978
)

D:\localhost\a.php:37:string 'Operation timed out after 35007 milliseconds with 0 bytes received' (length=66)

我发现如果你使用不同的端口,启动请求的PHP使用A端口,对请求的PHP的响应使用另一个端口,并且不会发生执行超时。

1 个答案:

答案 0 :(得分:0)

我知道为什么,因为php-cgi不是php-fpm,php-cgi不会自动启动新进程,所以一旦被占用就会被锁定。