TTFB: CLI + Lib to Measure the TTFB of HTTP/1.1 Requests
Similar to the network tab in Google Chrome or Mozilla Firefox, this crate helps you find the timings for:
- DNS lookup (if domain is specified, i.e. no IP is given)
- TCP connection start
- TLS handshake (if https/TLS is used)
- Initial GET-Request
- TTFB (Time To First Byte)
It builds upon the crates trust-dns-resolver for modern and secure DNS resolving of domains and native-tls for handling TLS v1.2/1.3.
Usage Binary/CLI tool
Install with cargo install ttfb
. It takes one argument and passes it to the library.
The string you pass here as first argument is the same as for the library function.
Usage Library
The library exposes the function ttfb(url: String)
. The string can be for example:
phip1611.de
(defaults tohttp://
)http://phip1611.de
https://phip1611.de
https://phip1611.de?foo=bar
https://sub.domain.phip1611.de?foo=bar
http://12.34.56.78/foobar
12.34.56.78/foobar
(defaults tohttp://
)12.34.56.78
(defaults tohttp://
)
Example Output
TTFB for https://phip1611.de (ttfb@v1.0.0)
DNS-Lookup: 1.68ms (probably cached)
TCP-Connect: 39.12ms
TLS-Handshake: 39.84ms
HTTP-Get-Send: 0.02ms
HTTP-TTFB: 86.99ms
Rust version
This crate was developed and tested with rustc-nightly 1.55 and rustc-stable 1.53. It should work with older versions too, because I don't use special features in the code. Maybe the other libraries could block older compilers, I'm not sure.