thlib / php-curl-multi-basic
Basic implementation of PHP curl_multi. Minimal code, easy to configure, better memory management, no double loop, no 100% CPU usage error.
1.0.2
2020-04-10 11:31 UTC
Requires
- php: >=5.3.0
This package is auto-updated.
Last update: 2025-04-24 20:58:10 UTC
README
Basic implementation of PHP curl multi
There are many implementations of curl multi, but the majority suffer from high CPU usage, inefficient memory management and run only after each request has finished instead of immediately.
Here is an example of how to avoid all of those issues without overloading it with functionality.
require 'CurlMulti.php';
$handles = [
[
// regular url
CURLOPT_URL=>"http://example.com/",
CURLOPT_FOLLOWLOCATION=>false,
CURLOPT_WRITEFUNCTION=>function($ch, $body)
{
print $body;
return strlen($body);
}
],
[
// invalid url
CURLOPT_URL=>"httpzzz://example.com/",
CURLOPT_FOLLOWLOCATION=>false,
CURLOPT_WRITEFUNCTION=>function($ch, $body)
{
print $body;
return strlen($body);
}
],
[
// url with a redirect
CURLOPT_URL=>"http://www.php.net",
CURLOPT_FOLLOWLOCATION=>false,
CURLOPT_HEADERFUNCTION=>function($ch, $header)
{
print "header from http://www.php.net: ".$header;
return strlen($header);
},
CURLOPT_WRITEFUNCTION=>function($ch, $body)
{
print $body;
return strlen($body);
}
]
];
//create the multiple cURL handle
$CurlMulti = new CurlMulti();
foreach($handles as $opts) {
// create cURL resources
$ch = curl_init();
// set URL and other appropriate options
curl_setopt_array($ch, $opts);
// add the handle
$CurlMulti->add($ch);
}
$statusCode = $CurlMulti->run(function($ch, $statusCode) {
$info = curl_getinfo($ch);
if ($statusCode !== CURLE_OK) {
// handle the error somehow
print "Curl handle error: ".curl_strerror($statusCode)." for ".$info['url'].PHP_EOL;
return;
}
//$body = curl_multi_getcontent($ch);
//print $body;
});
if ($statusCode !== CURLM_OK) {
print "Curl multi handle error: ".curl_multi_strerror($statusCode)." for ".$info['url'].PHP_EOL;
}