Skip to content

Enabling support for Prometheus

Please be aware Prometheus support is alpha at best, It hasn't been extensively tested and is still in development All it provides is the sending of data to a a Prometheus PushGateway. Please be careful when enabling this support you use it at your own risk!

Requirements (Older versions may work but haven't been tested

  • Prometheus >= 2.0
  • PushGateway >= 0.4.0
  • Grafana
  • PHP-CURL

The setup of the above is completely out of scope here and we aren't really able to provide any help with this side of things.

What you don't get

  • Pretty graphs, this is why at present you need Grafana. You need to build your own graphs within Grafana.
  • Support for Prometheus or Grafana, we would highly recommend that you have some level of experience with these.

RRD will continue to function as normal so LibreNMS itself should continue to function as normal.

Configuration

poller/prometheus

lnms config:set prometheus.enable true
lnms config:set prometheus.url 'http://127.0.0.1:9091'
lnms config:set prometheus.job 'librenms'
lnms config:set prometheus.prefix 'librenms'

Prefix

Setting the 'prefix' option will cause all metric names to begin with the configured value.

For instance without setting this option metric names will be something like this:

OUTUCASTPKTS
ifOutUcastPkts_rate
INOCTETS
ifInErrors_rate

Configuring a prefix name, for example 'librenms', instead caused those metrics to be exposed with the following names:

librenms_OUTUCASTPKTS
librenms_ifOutUcastPkts_rate
librenms_INOCTETS
librenms_ifInErrors_rate

Sample Prometheus Scrape Config (for scraping the Push Gateway)

- job_name: pushgateway
  scrape_interval: 300s
  honor_labels: true
  static_configs:
    - targets: ['127.0.0.1:9091']

The same data then stored within rrd will be sent to Prometheus and recorded. You can then create graphs within Grafana to display the information you need.