February 24, 2023

Reading Time:

Using Prometheus Blackbox Exporter to Monitor URL Endpoints​

Share

One of the basic, but essential steps in monitoring your system is to treat it as a blackbox and to monitor the URL front door to your system. This strategy can also be used to measure the uptime of your system.

There are several popular open source observability tools out there which can be used to achieve this. In this blog, we will look at using Prometheus and Grafana as the underlying tools to accomplish this. We will discuss two approaches:

  1. Using docker-compose
  2. Using OpsVerse’s ObserveNow stack

Using docker-compose

Installing Prometheus and Grafana

The quickest way to run Prometheus and Grafana for testing purposes is to use docker-compose. The repo https://github.com/docker/awesome-compose/tree/master/prometheus-grafana has a good sample docker-compose setup that can be used for this purpose.

git clone https://github.com/docker/awesome-compose.git
cd awesome-compose/prometheus-grafana/
sudo docker-compose up -d

Check if everything is up and running:

$ sudo docker ps
CONTAINER ID   IMAGE             COMMAND                  CREATED          STATUS          PORTS                                       NAMES
b6f474fb7ee5   prom/prometheus   "/bin/prometheus --c…"   27 minutes ago   Up 27 minutes   0.0.0.0:9090->9090/tcp, :::9090->9090/tcp   prometheus
f1e2b600827e   grafana/grafana   "/run.sh"                27 minutes ago   Up 27 minutes   0.0.0.0:3000->3000/tcp, :::3000->3000/tcp   grafana

The newly installed Grafana can be accessed at https://:3000. The default login credentials are admin/grafana.

Configure the blackbox exporter

Add a new file blackbox.yml with the following:

modules:
  http_2xx:
    prober: http
    timeout: 5s
    https:
      valid_status_codes: [] #default to 2xx
      method: GET

Edit the compose.yaml file and add the following:

blackbox_exporter:
  image: prom/blackbox-exporter
  ports:
    - "9115:9115"
  dns: 8.8.8.8
  restart: always
  ports:
    - "9115:9115"
  volumes:
    - "./:/config"
 command: '--config.file=/config/blackbox.yml'

Setup the scrape config by adding  the following to the end of the prometheus/prometheus.yml file:

Restart docker-compose:

	sudo docker-compose down
	sudo docker-compose up -d

This should start the following containers:

- job_name: 'blackbox'
  metrics_path: /probe
  params:
    module: [http_2xx]
  static_configs:
    - targets:
        - https://wronghost.com
        - https://opsverse.io
  relabel_configs:
    - source_labels: [__address__]
      regex: (.*)(:80)?
      target_label: __param_target
    - source_labels: [__param_target]
      regex: (.*)
      target_label: instance
      replacement: ${1}
    - source_labels: []
      regex: .*
      target_label: __address__
      replacement: blackbox_exporter:9115
$ sudo docker ps
CONTAINER ID   IMAGE                    COMMAND                  CREATED         STATUS         PORTS                                       NAMES
b2b0ec5be8da   grafana/grafana          "/run.sh"                4 minutes ago   Up 4 minutes   0.0.0.0:3000->3000/tcp, :::3000->3000/tcp   grafana
d78945307409   prom/prometheus          "/bin/prometheus --c…"   4 minutes ago   Up 4 minutes   0.0.0.0:9090->9090/tcp, :::9090->9090/tcp   prometheus
8fa5098fc164   prom/blackbox-exporter   "/bin/blackbox_expor…"   4 minutes ago   Up 4 minutes   0.0.0.0:9115->9115/tcp, :::9115->9115/tcp   prometheus-grafana_blackbox_exporter_1

Visualize the collected metrics

Import the Grafana dashboard https://grafana.com/grafana/dashboards/7587-prometheus-blackbox-exporter/ to visualize the collected metrics:

Using OpsVerse’s ObserveNow Stack

OpsVerse’s ObserveNow is a full stack observability solution based on OSS tools that brings together metrics, logs and distributed traces under one platform. It makes the above steps much easier.

Launch the stack

Launch an instance of OpsVerse’s ObserveNow through the OpsVerse admin console. More info here: https://www.youtube.com/watch?v=WEfpPZt_x3s

Enable The Blackbox exporter agent

Prerequisites: The OpsVerse agent is installed in the cluster and the corresponding values.yaml is available on your machine. Add the following to the values.yaml:

blackbox-exporter: 
  enabled: true

Rerun the following command to update the agent’s installation with the blackbox configuration:

helm upgrade --install devopsnow-agent -n devopsnow --create-namespace 
observe-agent --repo https://registry.devopsnow.io/chartrepo/public -f values.yaml

Refer to the official blackbox chart on prometheus github to check the values that can be overridden as part of the helm chart that is pre-installed on the OpsVerse-agent

https://github.com/prometheus-community/helm-charts/blob/main/charts/prometheus-blackbox-exporter/values.yaml
https://github.com/prometheus/blackbox_exporter/blob/master/example.yml

After enabling the exporter, add a custom scrape job as part of the victoria-metrics-agent field, defined in the same values file, similar to the following:

- job_name: 'blackbox-grafana-venus'
          scrape_timeout: 30s
          scrape_interval: 30s
          metrics_path: /probe
          params:
           module: [http_2xx]
          static_configs:
            - targets:
              - https://wronghost.com
              - https://opsverse.io
          relabel_configs:
            - source_labels: [__address__]
              target_label: __param_target
            - source_labels: [__param_target]
              target_label: instance
            - target_label: __address__
              replacement: devopsnow-agent-blackbox-exporter.devopsnow:9115

Notice how the scrape job contains the urls of the targets that need to be monitored.

It is important to configure the relabel_configs, especially the __address__ target label, which helps the prometheus agent to identify and scrape the blackbox service for metrics.

Visualize the collected metrics

OpsVerse’s ObserveNow stack already has prepackaged dashboards which should now display telemetry collected from the agent.


OpsVerse ObserveNow is a managed, battle-tested, scalable observability platform built on top of open source software and open standards. ObserveNow can be deployed as a cloud service or as a private SaaS installation within your own cloud (AWS/GCS/Azure). If you’d like to explore OpsVerse ObserveNow, click here to start a free trial today!

Share

Written by Amogh Prakash

Subscribe to the OpsVerse blog

New posts straight to your inbox