Prometheus Web Exporter
Prometheus Web Exporter collects information about status of web pages from internet.
It send a request to a webpage and runs one or more css queries on the result. Number of results for each query becomes a metric on premetheus.
Configuration
Web configuration is done with a file named web_exporter.yaml with the same directory with the executable here is an example fonfiguration for web_exporterl.yaml fie
ip_address: "0.0.0.0"
port: 3030
metrics_path: "metrics"
targets:
- url: "https://www.rust-lang.org/"
queries:
- "#language-values div.flex-none section"
- "header h1"
- "footer div.attribution"
- url: "https://www.rust-lang.org/invalid-page-with-404-response"
queries:
- "div.flex"
- "div"
- url: "https://www.page-does-not-exist.io/"
queries:
- "div"
- url: "https://www.rust-lang.org/invalid-css-query"
queries:
- "**XX**"
Configuration above will generate metrics like following:
web_exporter_response_duration_milliseconds{url="https://www.rust-lang.org/", status=200, error=0} 640
web_exporter_response_response_size_bytes{url="https://www.rust-lang.org/", status=200, error=0} 19220
web_exporter_query_count{url="https://www.rust-lang.org/", query="#language-values div.flex-none section", status=200, error=0} 3
web_exporter_query_count{url="https://www.rust-lang.org/", query="header h1", status=200, error=0} 1
web_exporter_query_count{url="https://www.rust-lang.org/", query="footer div.attribution", status=200, error=0} 1
web_exporter_response_duration_milliseconds{url="https://www.rust-lang.org/invalid-page-with-404-response", status=404, error=0} 292
web_exporter_response_response_size_bytes{url="https://www.rust-lang.org/invalid-page-with-404-response", status=404, error=0} 8244
web_exporter_query_count{url="https://www.rust-lang.org/invalid-page-with-404-response", query="div.flex", status=404, error=0} 6
web_exporter_query_count{url="https://www.rust-lang.org/invalid-page-with-404-response", query="div", status=404, error=0} 14
web_exporter_response_duration_milliseconds{url="https://www.page-does-not-exist.io/", status=0, error=1} 270
web_exporter_response_response_size_bytes{url="https://www.page-does-not-exist.io/", status=0, error=1} 0
web_exporter_response_duration_milliseconds{url="https://www.rust-lang.org/invalid-css-query", status=404, error=0} 306
web_exporter_response_response_size_bytes{url="https://www.rust-lang.org/invalid-css-query", status=404, error=0} 8244
web_exporter_query_count{url="https://www.rust-lang.org/invalid-css-query", query="**XX**", status=404, error=0} 0
web_exporter_scrape_duration_milliseconds 641
Logging:
Logging configuration can be provided through environment variables. To run the project with info logging level you can run it like this
How to get it
With docker.
# Download sample configuration from github
# Rename it to web_exporter.yaml
# Run Docker and mount configuration file to container
# endpoint should be on http://localhost:3030/metrics
With Cargo
# First install web_exporter with cargo.
# After installation cargo will show where it is installed it is likely on
# ~/.cargo/bin. Go to installation folder and download sample config next to executable.
# Download sample configuration from github
# Rename it to web_exporter.yaml
# run web_exporter
# endpoint should be on http://localhost:3030/metrics