如何使PHP中的多个file_get_contents运行更快?

问题描述 投票:3回答:2

我们正在构建执行重复file_get_contents的API。我有一个用户ID数组,file_get_contents()的数量将重复该数组中内容的数量。我们将处理数千个请求。

function request($userid) {
    global $access_token;
    $url = 'https://<api-domain>'.$userid.'?access_token='.$access_token;
    $response = file_get_contents($url);
    return json_decode($response);
}

function loopUserIds($arrayUserIds) {
    global $countFollowers;
    $arrayAllUserIds = array();
    foreach ($arrayUserIds as $userid) {
        $followers = request($userid);
        ...
    }
    ...
}

我的担心是,获取所有内容需要时间。由于该函数也将在循环中调用。请告知我们如何使它(许多file_get_contents()请求)运行得更快?

php api loops file-get-contents
2个回答
1
投票

如@HankyPanky所述,您可以使用curl_multi_exec()同时执行许多并发请求。

这样的事情应该有所帮助:

function fetchAndProcessUrls(array $urls, callable $f) {

    $multi = curl_multi_init();
    $reqs  = [];

    foreach ($urls as $url) {
        $req = curl_init();
        curl_setopt($req, CURLOPT_URL, $url);
        curl_setopt($req, CURLOPT_HEADER, 0);
        curl_multi_add_handle($multi, $req);
        $reqs[] = $req;
    }

    // While we're still active, execute curl
    $active = null;

    // Execute the handles
    do {
        $mrc = curl_multi_exec($multi, $active);
    } while ($mrc == CURLM_CALL_MULTI_PERFORM);

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

    // Close the handles
    foreach ($reqs as $req) {
        $f(curl_multi_getcontent($req));
        curl_multi_remove_handle($multi, $req);
    }
    curl_multi_close($multi);
}

您可以这样使用它:

$urlArray = [ 'http://www.example.com/' , 'http://www.example.com/', ... ];

fetchAndProcessUrls($urlArray, function($requestData) { 

    /* do stuff here */ 

    // e.g.
    $jsonData = json_decode($requestData, 1); //
});

0
投票

当curl_multi_exec不可用时,您可以在重用$ ch时获得性能,而不必为每个文件创建一个新文件,当从同一主机下载时,该文件将重用连接。

© www.soinside.com 2019 - 2024. All rights reserved.