Skip to content

rea1shane/exporter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

63 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Prometheus exporter framework

Lets you create a powerful exporter in two minutes.

Features

This framework is extracted from node_exporter. You can use all the features of node_exporter with this framework:

Example

There is an example in _example.

Usage

Creating your exporter is very easy:

  1. Create some collectors implement github.com/rea1shane/exporter/collector.Collector and call github.com/rea1shane/exporter/collector.RegisterCollector in their init function.
  2. Call the github.com/rea1shane/exporter.Run function to start the exporter.

Now, everything is done!

Tips

  • Same as node_exporter, the framework uses log/slog as the logger and github.com/alecthomas/kingpin/v2 as the command line argument parser.
  • github.com/rea1shane/exporter/collector.ErrNoData indicates the collector found no data to collect, but had no other error. If necessary, return it in the github.com/rea1shane/exporter/collector.Collector's Update method.
  • github.com/rea1shane/exporter/metric.TypedDesc makes easier to create metrics.
  • If you are not using github.com/rea1shane/exporter/metric.TypedDesc to create metrics, you can use github.com/rea1shane/exporter/util.AnyToFloat64 function to convert the data to float64.

Optional features

PProf statistics

Add _ "net/http/pprof" to imports to enable PProf statistics:

package main

import (
	_ "net/http/pprof"
)

See prometheus/exporter-toolkit#196 for more information.

Building, running and more

Using Prometheus's Makefile.common file

You can using Prometheus's Makefile.common file to building or running an exporter that uses this framework just like node_exporter. All you need is:

  1. Copy prometheus/node_exporter/Makefile.common to your repository root path.
  2. Create .promu.yml like prometheus/node_exporter/.promu.yml.
  3. Create Makefile like prometheus/node_exporter/Makefile.
  4. Create VERSION like prometheus/node_exporter/VERSION.

Now your repository will looks like this:

your_exporter
├── .promu.yml
├── Makefile.common
├── Makefile
├── VERSION
└── ...

Then you can execute everything that has been defined in Makefile.common. Some examples:

Manually

If you want to build in a simple way, see example's Makefile. (Note: Also need a VERSION file and may missing tags info)