/volume_exporter

Promethues Exporter written in GO to export metrics related to disk/volume/pv

Primary LanguageGoApache License 2.0Apache-2.0

Volume Exporter

Build Status License Language Docker Docker Pulls Go Report Card Maintainability Test Coverage

Useful to monitor disk/volume/PV storage, for various reasons

  • Host path cannot to be mounted to container/Deamonset
  • In ability of Cloud provider to gather information about PV

This is what happens in corporates, multiple projects run on same and/or different nodes, and hence host path mount cannot be granted, further node scrapping cannot be done as well, since it requires cluster role, as in a cluster multiple projects/namespace runs, and hence cluster role is not granted to project teams.

Above I have listed some of the use cases ( real world ) where in node exporter cannot be deployed, should this stop us from monitoring pv/volumes/disk?

This is altogether a different exporter and does not duplicate any existing exporters. Its area of focus (Where ever node exporter cannot be deployed) is altogether different.

It just fills the vacuum

Wiki

Refer project wiki for more details

Running

Command Line locally

go run main.go --volume-dir=practices:E:\practices

Usage

Usage of Temp\go-build869878202\b001\exe\main.exe:
  -volume-dir value
        Volumes to report, the format is volumeName:VolumeDir;
         For example ==> logs:/app/logs; can be used multiple times to provide more than one value
  -web.listen-address string
        Address to listen on for web interface and telemetry. (default ":9888")
  -web.telemetry-path string
        Path under which to expose metrics. (default "/metrics")

Docker Locally

docker run --rm -p 9888:9888 -it mnadeem/volume_exporter --volume-dir=bin:/bin

Deploy It in Cloud

Add as a sidecar

        - name: volume-exporter
          image:  mnadeem/volume_exporter
          imagePullPolicy: "Always"
          args:
            - --volume-dir=prometheus:/prometheus
          ports:
          - name: metrics-volume
            containerPort: 9888
          volumeMounts:
          - mountPath: /prometheus
            name: prometheus-data
            readOnly: true

Config

Flag Description
web.listen-address Address to listen on for web interface and telemetry. Default is 9888
web.telemetry-path Path under which to expose metrics. Default is /metrics
volume-dir volumes to report, the format is volumeName:VolumeDir, For example ==> logs:/app/logs, you can use this flag multiple times to provide multiple volumes

Exporterd Metrics

metrics Type Description
volume_bytes_total{volume_name=”someName”, volume_path=”/some/path”} Gauge Total size of the volume/disk
volume_bytes_free{volume_name=”someName”, volume_path=”/some/path”} Gauge Free size of the volume/disk
volume_bytes_used{volume_name=”someName”, volume_path=”/some/path”} Gauge Used size of volume/disk

Here is a sample metrics exporterd by running

docker run --rm -p 9888:9888  -it mnadeem/volume_exporter:latest  -volume-dir=bin:/bin -volume-dir=etc:/etc
# HELP volume_bytes_free Free size of the volume/disk
# TYPE volume_bytes_free gauge
volume_bytes_free{volume_name="bin",volume_path="/bin"} 4.341569536e+10
volume_bytes_free{volume_name="etc",volume_path="/etc"} 4.341569536e+10
# HELP volume_bytes_total Total size of the volume/disk
# TYPE volume_bytes_total gauge
volume_bytes_total{volume_name="bin",volume_path="/bin"} 6.391887872e+10
volume_bytes_total{volume_name="etc",volume_path="/etc"} 6.391887872e+10
# HELP volume_bytes_used Used size of volume/disk
# TYPE volume_bytes_used gauge
volume_bytes_used{volume_name="bin",volume_path="/bin"} 2.050318336e+10
volume_bytes_used{volume_name="etc",volume_path="/etc"} 2.050318336e+10
# HELP volume_exporter_build_info A metric with a constant '1' value labeled by version, revision, branch, and goversion from which volume_exporter was built.
# TYPE volume_exporter_build_info gauge
volume_exporter_build_info{branch="",goversion="go1.15",revision="",version=""} 1
# HELP volume_percentage_used Percentage of volume/disk Utilization
# TYPE volume_percentage_used gauge
volume_percentage_used{volume_name="bin",volume_path="/bin"} 32.07688208958619
volume_percentage_used{volume_name="etc",volume_path="/etc"} 32.07688208958619

Why Volume Exporter

  • Because there are cases where in you dont have permission to mount host path
  • Beacause there are cases where you dont have access to nodes.
  • Very light weight (just 6.84 MB of image size)
  • Conumes very less CPU and Memory and can be added as sidecar.
  • Configurable, you can pass multiple volumes to track.

Support

If you need help using volume_exporter feel free to drop an email or create an issue (preferred)

Contributions

To help development you are encouraged to

  • Provide suggestion/feedback/Issue
  • pull requests for new features
  • Star 🌟 the project

View My profile on LinkedIn

Inspired From