utopia-php / dns
Lite & fast micro PHP DNS server abstraction that is **easy to use**.
Installs: 11 619
Dependents: 1
Suggesters: 0
Security: 0
Stars: 4
Watchers: 6
Forks: 0
Open Issues: 2
pkg:composer/utopia-php/dns
Requires
- php: >=8.0
- utopia-php/console: 0.0.*
- utopia-php/telemetry: ^0.1.1
Requires (Dev)
- laravel/pint: 1.2.*
- phpstan/phpstan: 1.8.*
- phpunit/phpunit: ^9.3
- rregeer/phpunit-coverage-check: ^0.3.1
- swoole/ide-helper: 4.6.6
This package is auto-updated.
Last update: 2025-10-25 16:36:50 UTC
README
Utopia DNS is a simple and lite abstraction layer for quickly setting up a DNS server. This library is aiming to be as simple and easy to learn and use. This library is maintained by the Appwrite team.
Although this library is part of the Utopia Framework project it is dependency free, and can be used as standalone with any other PHP project or framework.
Getting started
Install using composer:
composer require utopia-php/dns
Using the DNS server
Init your DNS server with your preferred adapter and resolver. The adapter is used for running the UDP server to serve DNS requests, and the resolver will be used to answering DNS queries with proper results. You can and in most cases should implement your own resolver by extending src/DNS/Resolver.php
<?php require_once __DIR__.'/init.php'; use Appwrite\DNS\Server; use Appwrite\DNS\Adapter\Swoole; use Appwrite\DNS\Resolver\Mock; $server = new Swoole('0.0.0.0', 8000); // Swoole based UDP server running on port 8000 $resolver = new Mock(); // Mock resolver. Always returns 127.0.0.1 as the result $dns = new Server($server, $resolver); $dns->start();
Using the DNS client
Utopia DNS also provides a simple, dependency‑free DNS client that can be used to perform queries against any DNS server. This client is ideal for applications that need to look up records on demand. It supports querying all sorts of DNS records (A, MX, TXT, AAAA, SRV, etc.).
Example Usage
Below is an example of how to use the DNS client:
<?php require_once __DIR__ . '/vendor/autoload.php'; use Utopia\DNS\Client; $client = new Client('8.8.8.8'); // Query against Google's public DNS try { // Query for A records for example.com $records = $client->query('example.com', 'A'); foreach ($records as $record) { echo 'Name: ' . $record->getName() . "\n"; echo 'Type: ' . $record->getTypeName() . "\n"; echo 'TTL: ' . $record->getTTL() . "\n"; echo 'Data: ' . $record->getRdata() . "\n\n"; } // Query for other record types (e.g. MX, TXT, AAAA, SRV) // $mxRecords = $client->query('example.com', 'MX'); // $txtRecords = $client->query('example.com', 'TXT'); // ... } catch (Exception $e) { echo "DNS query failed: " . $e->getMessage(); }
How it works
Instantiate the client
Create a new instance of the Client class and specify the DNS server you wish to query. In the example above, we use Google's DNS server (8.8.8.8).
Perform a query
Use the query() method with the desired domain and record type (for example, 'A' for an IPv4 address) to retrieve DNS records.
The client returns an array of Record objects. These objects contain the queried domain name, type (both numeric and human‑readable), TTL, and record data. Optional fields (such as priority, weight, and port for MX and SRV records) are available via their getters.
Error handling
The query is wrapped in a try‑catch block to handle any exceptions that may occur during the DNS lookup.
Supported DNS records
- A
- NS
- CNAME
- SOA
- WKS
- PTR
- HINFO
- MX
- TXT
- RP
- SIG
- KEY
- LOC
- NXT
- AAAA
- CERT
- A6
- AXFR
- IXFR
- 
Adapters
Below is a list of supported server adapters, and their compatibly tested versions alongside a list of supported features and relevant limits.
| Adapter | Status | Info | Version | 
|---|---|---|---|
| Native | ✅ | A native PHP Socket | 8.0 | 
| Swoole | ✅ | PHP Swoole UDP Server | 4.8.4 | 
| Workerman | 🛠 | - | - | 
| ReactPHP | 🛠 | - | - | 
 ✅  - supported, 🛠  - work in progress
Future possibilities
Currently this library only support DNS over UDP. We could add support for both DNS over TLS and HTTPS. We should also add better support for query flags, and possibly create some more predefined resolvers.
System requirements
Utopia Framework requires PHP 8.0 or later. We recommend using the latest PHP version whenever possible.
Running tests
Run tests for this library using the provided Docker container.
docker compose exec -t dns-server vendor/bin/phpunit --configuration phpunit.xml
Benchmarking
The library includes a benchmarking tool to measure DNS server performance under load. The benchmark tests various record types and provides detailed performance metrics.
Running the benchmark
# Run with default settings php tests/benchmark.php # Run with custom configuration php tests/benchmark.php --server=127.0.0.1 --port=5300 --iterations=1000 --concurrency=20
Options
- --server: DNS server IP address (default: 127.0.0.1)
- --port: DNS server port (default: 5300)
- --iterations: Number of queries per record type (default: 10000)
- --concurrency: Number of concurrent requests (default: 10)
Metrics Provided
- Requests per second (RPS)
- Response time statistics (min, max, avg)
- Latency distribution (p50, p75, p90, p95, p99)
- Time series analysis
- Success/failure rates
- Detailed error reporting
Example Output
--- Benchmark Results ---
Total Requests: 40000
Successful: 40000
Failed: 0
Total Time: 25.34 seconds
Requests Per Second: 1578.93 req/s
Min Response Time: 12.45 ms
Max Response Time: 45.67 ms
Avg Response Time: 23.45 ms
--- Latency Distribution ---
p50: 22.34 ms
p75: 28.56 ms
p90: 35.78 ms
p95: 39.12 ms
p99: 42.89 ms