1
0
mirror of https://github.com/danog/dns.git synced 2024-11-27 04:24:48 +01:00
dns/examples/benchmark.php

43 lines
1.1 KiB
PHP
Raw Normal View History

<?php
require __DIR__ . "/_bootstrap.php";
use Amp\Dns;
use Amp\Loop;
2017-09-09 19:40:48 +02:00
print "Downloading top 500 domains..." . PHP_EOL;
2019-01-25 02:27:47 +01:00
$domains = \file_get_contents("https://moz.com/top500/domains/csv");
$domains = \array_map(function ($line) {
return \trim(\explode(",", $line)[1], '"/');
}, \array_filter(\explode("\n", $domains)));
// Remove "URL" header
2019-01-25 02:27:47 +01:00
\array_shift($domains);
Loop::run(function () use ($domains) {
print "Starting sequential queries...\r\n\r\n";
2017-09-09 19:40:48 +02:00
$timings = [];
for ($i = 0; $i < 10; $i++) {
2019-01-25 02:27:47 +01:00
$start = \microtime(1);
$domain = $domains[\random_int(0, \count($domains) - 1)];
2017-09-09 19:40:48 +02:00
try {
pretty_print_records($domain, yield Dns\resolve($domain));
} catch (Dns\DnsException $e) {
pretty_print_error($domain, $e);
}
2017-09-09 19:40:48 +02:00
2019-01-25 02:27:47 +01:00
$time = \round(\microtime(1) - $start, 2);
2017-09-09 19:40:48 +02:00
$timings[] = $time;
2019-01-25 02:27:47 +01:00
\printf("%'-74s\r\n\r\n", " in " . $time . " ms");
}
2017-09-09 19:40:48 +02:00
2019-01-25 02:27:47 +01:00
$averageTime = \array_sum($timings) / \count($timings);
print "{$averageTime} ms for an average query." . PHP_EOL;
});