The postman exporter allows blackbox probing with Prometheus using Postman collections.
There are several exporters available for collecting metrics with Prometheus. Most of it focus on providing whitebox metrics. The Prometheus blackbox exporter already allows probing of endpoints over HTTP, HTTPS, DNS, TCP and ICMP. However, it is complex or sometimes impossible to probe more sophisticated sequences of HTTP/HTTPS requests and validate its responses.
The postman exporter aims to be able to carry even complex test procedures. These should be easy to create with the widely used Postman Platform for API Development. It uses Newman (as library) to run Postman collections and provides metrics about that execution.
Prerequisites:
- Node.js >= v20
Install:
- GIT clone the project or download the latest release
- Run
npm i
in the project folder to install required dependencies
Run:
- Run
npm start
in the project folder to start the service.
By default it will listen on port 3000.
The configuration consists of two parts.
- Setup the exporter
- Setup Prometheus to scrape postman exporter targets
Probe configuration
Edit the configuration file config/probes.js to fit to your needs.
A Postman collection and associated options are combined to form a probe. Several probes can be configured to make them available via the /probes
endpoint.
See also newman run options for details on the options available.
Example:
module.exports = {
// Each probe requires a Postman collection and allows for additional options.
// Execute by requesting /probe/<probe_name>
// Probe name
// <probe_name>
// String of non-registered URL characters (A–Z, a–z, 0-9, -._~)
"example": {
// see newman documentation for all available parameters
// https://github.com/postmanlabs/newman#newmanrunoptions-object--callback-function--run-eventemitter
options: {
collection: require('./example.json')
},
// Optional: Set labels that will be added to all probe metrics.
customLabels: {
example_label: "example_label_value",
another_example_label: "another value"
}
},
"example2": {
options: {
collection: require('./eample2-collection.json'),
environment: require('./example2-environment.json'),
sslClientCert: __dirname + '/' + 'cert.pem',
sslClientKey: __dirname + '/' + 'key.pem',
timeoutRequest: 2000,
folder: 'myFolder'
}
}
};
Service configuration
Service configuration is available via configuration file config/config.js or environment variables:
POSTMAN_BLACKBOX_EXPORTER_PORT
Network port to bind to.
Default: 3000POSTMAN_BLACKBOX_EXPORTER_TIMEOUT
Server timeout in milliseconds.
Default: 120000
If necessary, think about adjusting the scrape timeout also in Prometheus.POSTMAN_BLACKBOX_EXPORTER_LOGLEVEL
Loglevel (debug|info|warn|error).
Default: infoPOSTMAN_BLACKBOX_EXPORTER_PROBE_CONFIG_FILE
Path to probe configuration file.
Default: config/probes.jsPOSTMAN_BLACKBOX_EXPORTER_PROBE_DEBUG
Allow/disallow (true|false) probe debug mode.
! Debug output may expose secrets contained in requests/responses, etc.. !
Default: false
To scrape the probes, follow the multi-target exporter pattern and use relabeling.
Example:
scrape_configs:
- job_name: 'postman-exporter'
scrape_interval: 1m
scrape_timeout: 10s
scheme: http
metrics_path: /probe
static_configs:
- targets:
- example
relabel_configs:
- source_labels: [__address__]
target_label: probe
- source_labels: [__metrics_path__,__address__]
separator: '/'
target_label: __metrics_path__
- target_label: __address__
replacement: monitoring-postman-exporter
-
GET /
Display overview page -
GET /probe/:probe[?debug=true]
Run probe and show metrics
Parameters:
probe
: (required) the probe to run. E. g. /probe/example
Arguments:
?debug=true
: (optional) If added, newmans run summary object is returned instead of metrics. Probe debug also needs to be enabled in configuration. -
GET /config
Show active configuration -
GET /metrics
Node.js server metrics -
GET /-/ready
Returns status code 200 when the service is running
- probe_pm_success: overall probe success (no failures for collection run)
- Values from https://github.com/postmanlabs/newman#newmanruncallbackerror-object--summary-object
- summary.run.transfers.responseTotal
- summary.run.stats.*
- summary.run.timings.*
- probe_pm_assertion_failure: assertion failures with iteration, position, request_name, assertion labels
- Number of summary.run.failures
-
Run with included example
docker run --rm -p 3000:3000 ghcr.io/hudeldudel/postman-exporter
-
Run with your own configuration
- collection.json - your collection
- probes.js - your probes configuration using collection.json
docker run \ -d \ --restart=always \ -p 3000:3000 \ -v $(PWD)/myconfig/probes.js:/app/config/probes.js \ -v $(PWD)/myconfig/collection.json:/app/config/collection.json \ ghcr.io/hudeldudel/postman-exporter