Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/prometheus-community/ipmi_exporter
Remote IPMI exporter for Prometheus
https://github.com/prometheus-community/ipmi_exporter
Last synced: 3 days ago
JSON representation
Remote IPMI exporter for Prometheus
- Host: GitHub
- URL: https://github.com/prometheus-community/ipmi_exporter
- Owner: prometheus-community
- License: mit
- Created: 2018-05-24T14:30:09.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-03-18T15:53:47.000Z (8 months ago)
- Last Synced: 2024-04-15T07:16:38.502Z (7 months ago)
- Language: Go
- Homepage:
- Size: 3.68 MB
- Stars: 419
- Watchers: 73
- Forks: 124
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
Prometheus IPMI Exporter
========================[![Build Status](https://circleci.com/gh/prometheus-community/ipmi_exporter.svg?style=svg)](https://circleci.com/gh/prometheus-community/ipmi_exporter)
This is an IPMI exporter for [Prometheus][prometheus].
[prometheus]: https://prometheus.io "Prometheus homepage"
It supports both the regular `/metrics` endpoint, exposing metrics from the
host that the exporter is running on, as well as an `/ipmi` endpoint that
supports IPMI over RMCP, implementing the multi-target exporter pattern. If you
plan to use the latter, please read the guide [Understanding and using the
multi-target exporter pattern][multi-target] to get the general idea about the
configuration.[multi-target]: https://prometheus.io/docs/guides/multi-target-exporter/
The exporter relies on tools from the [FreeIPMI][freeipmi] suite for the actual
IPMI implementation.[freeipmi]: https://www.gnu.org/software/freeipmi/ "FreeIPMI homepage"
## Installation
For most use-cases, simply download the [the latest release][releases].
[releases]: https://github.com/prometheus-community/ipmi_exporter/releases "IPMI exporter releases on Github"
For Kubernets, you can use the community-maintained [Helm chart][helm].
[helm]: https://github.com/prometheus-community/helm-charts/tree/main/charts/prometheus-ipmi-exporter "IPMI exporter Helm chart in the helm-charts Github repo"
Pre-built container images are available on [dockerhub][dockerhub] and
[quay.io][quay.io].[dockerhub]: https://hub.docker.com/r/prometheuscommunity/ipmi-exporter
[quay.io]: https://quay.io/repository/prometheuscommunity/ipmi-exporter### Building from source
You need a Go development environment. Then, simply run `make` to build the
executable:make
This uses the common prometheus tooling to build and run some tests.
Alternatively, you can use the standard Go tooling, which will install the
executable in `$GOPATH/bin`:go install github.com/prometheus-community/ipmi_exporter@latest
### Building a container image
You can build a container image with the included `docker` make target:
make promu
promu crossbuild -p linux/amd64 -p linux/arm64
make docker## Running
A minimal invocation looks like this:
./ipmi_exporter
Supported parameters include:
- `web.listen-address`: the address/port to listen on (default: `":9290"`)
- `config.file`: path to the configuration file (default: none)
- `freeipmi.path`: path to the FreeIPMI executables (default: rely on `$PATH`)For syntax and a complete list of available parameters, run:
./ipmi_exporter -h
Make sure you have the following tools from the [FreeIPMI][freeipmi] suite
installed:- `ipmimonitoring`/`ipmi-sensors`
- `ipmi-dcmi`
- `ipmi-raw`
- `bmc-info`
- `ipmi-sel`
- `ipmi-chassis`When running a container image, make sure to:
- set `config.file` to where the config file is mounted
- expose the default port (9290) or set `web.listen-address` accordingly**NOTE:** you should only use containers for collecting remote metrics.
## Configuration
The [configuration](docs/configuration.md) document describes both the
configuration of the IPMI exporter itself as well as providing some guidance
for configuring the Prometheus server to scrape it.## TLS and basic authentication
The IPMI Exporter supports TLS and basic authentication.
To use TLS and/or basic authentication, you need to pass a configuration file
using the `--web.config.file` parameter. The format of the file is described
[in the exporter-toolkit repository][toolkit].[toolkit]: https://github.com/prometheus/exporter-toolkit/blob/master/docs/web-configuration.md
## Exported data
For a description of the metrics that this exporter provides, see the
[metrics](docs/metrics.md) document.## Privileges
Collecting host-local IPMI metrics requires root privileges. See
[privileges](docs/privileges.md) document for how to avoid running the exporter
as root.