A prometheus exporter to get metrics from redfish based servers such as lenovo/dell/Supermicro servers.
An example configure given as an example:
hosts:
10.36.48.24:
username: admin
password: pass
default:
username: admin
password: pass
groups:
group1:
username: group1_user
password: group1_pass
Note that the default
entry is useful as it avoids an error
condition that is discussed in this issue.
One issue you may encounter is slow scrape times when collecting logs from BMCs. Sometimes these scrapes can take ~10minutes. If this becomes problematic the collection of logs can be configured as follows:
- via the the config file
To disable log collection you can set:
collectlogs: false
- via the
collectlogs
query parameter
For example:
curl '127.0.0.1:9123/redfish?target=10.10.12.23&collectlogs=false'
- Via a combination of both options
For example, collect metrics without logs by default:
Set:
collectlogs: false
Every hour or so, override the config setting and fetch the logs:
curl '127.0.0.1:9123/redfish?target=10.10.12.23&collectlogs=true'
The collectlogs
query parameter can be included in Prometheus config.
To build the redfish_exporter executable run the command:
make build
or build in centos 7 docker image
make docker-build-centos7
or build in centos 8 docker image
make docker-build-centos8
or we can also build a docker image using Dockerfile
-
running directly on linux
redfish_exporter --config.file=redfish_exporter.yml
and run
redfish_exporter -h
for more options. -
running in container
Also if you build it as a docker image, you can also run in container, just remember to replace your config
/etc/prometheus/redfish_exporter.yml
in container
We can get the metrics via
curl http://<redfish_exporter host>:9610/redfish?target=10.36.48.24
or by pointing your favourite browser at this URL.
PUT /-/reload
POST /-/reload
The /-/reload
endpoint triggers a reload of the redfish_exporter configuration.
500 will be returned when the reload fails.
Alternatively, a configuration reload can be triggered by sending SIGHUP
to the redfish_exporter process as well.
You can then setup Prometheus to scrape the target using something like this in your Prometheus configuration files:
- job_name: 'redfish-exporter'
# metrics_path defaults to '/metrics'
metrics_path: /redfish
# scheme defaults to 'http'.
static_configs:
- targets:
- 10.36.48.24 ## here is the list of the redfish targets which will be monitored
relabel_configs:
- source_labels: [__address__]
target_label: __param_target
- source_labels: [__param_target]
target_label: instance
- target_label: __address__
replacement: localhost:9610 ### the address of the redfish-exporter address, hence relpace localhost with the server IP address that redfish-export is running on
# (optional) when using group config add this to have group=my_group_name
- target_label: __param_group
replacement: my_group_name
Note that port 9610 has been reserved for the redfish_exporter.
- Enginetech EG520R-G20 (Supermicro Firmware Revision 1.76.39)
- Enginetech EG920A-G20 (Huawei iBMC 6.22)
- Lenovo ThinkSystem SR850 (BMC 2.1/2.42)
- Lenovo ThinkSystem SR650 (BMC 2.50)
- Dell PowerEdge R440, R640, R650, R6515, C6420
- GIGABYTE G292-Z20, G292-Z40, G482-Z54
- gofish provides the underlying library to interact servers