Skip to content

Commit f5bc12a

Browse files
committed
Add example for using rate limiter via MultiCurl::setRateLimit()
1 parent c4dfe8d commit f5bc12a

File tree

1 file changed

+48
-0
lines changed

1 file changed

+48
-0
lines changed
Lines changed: 48 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
<?php
2+
require __DIR__ . '/../vendor/autoload.php';
3+
4+
use Curl\MultiCurl;
5+
6+
$start_time = microtime(true);
7+
8+
$multi_curl = new MultiCurl();
9+
$multi_curl->setRateLimit('2/10s');
10+
11+
$multi_curl->beforeSend(function ($instance) use ($start_time) {
12+
echo
13+
sprintf('%.6f', round(microtime(true) - $start_time, 6)) . ' - ' .
14+
'request ' . $instance->id . ' start' . "\n";
15+
});
16+
17+
$multi_curl->success(function ($instance) use ($start_time) {
18+
echo
19+
sprintf('%.6f', round(microtime(true) - $start_time, 6)) . ' - ' .
20+
'request ' . $instance->id . ' successful (' . $instance->url . ')' . "\n";
21+
});
22+
$multi_curl->error(function ($instance) use ($start_time) {
23+
echo
24+
sprintf('%.6f', round(microtime(true) - $start_time, 6)) . ' - ' .
25+
'request ' . $instance->id . ' unsuccessful (' . $instance->url . ')' . "\n";
26+
});
27+
28+
$multi_curl->addGet('https://httpbin.org/ip');
29+
$multi_curl->addGet('https://httpbin.org/status/503');
30+
31+
$multi_curl->addGet('https://httpbin.org/ip');
32+
$multi_curl->addGet('https://httpbin.org/status/503');
33+
34+
$multi_curl->addGet('https://httpbin.org/ip');
35+
36+
$multi_curl->start();
37+
38+
// $ php multi_curl_get_with_rate_limit.php
39+
// 0.021839 - request 0 start
40+
// 0.021894 - request 1 start
41+
// 0.661308 - request 0 successful (https://httpbin.org/ip)
42+
// 0.661968 - request 1 unsuccessful (https://httpbin.org/status/503)
43+
// 10.024627 - request 2 start
44+
// 10.024694 - request 3 start
45+
// 10.114304 - request 2 successful (https://httpbin.org/ip)
46+
// 10.117299 - request 3 unsuccessful (https://httpbin.org/status/503)
47+
// 20.029945 - request 4 start
48+
// 20.112836 - request 4 successful (https://httpbin.org/ip)

0 commit comments

Comments
 (0)