Go to file
Jakub Klinkovský 6e2143ca62 Remove useless error message
All errors are already logged from the called functions: readSMARTctl,
resultCodeIsOk, jsonIsOk. Logging twice due to the same error is useless
and the "smartctl returned bad data for device" message is confusing
since that condition may happen when a device is in a low-power mode.

Signed-off-by: Jakub Klinkovský <j.l.k@gmx.com>
2022-11-06 11:56:41 +01:00
.circleci Release 0.7.0 (#50) 2022-08-05 03:37:13 +02:00
.github Update common Prometheus files 2022-06-17 19:51:12 +00:00
gentoo/app-metrics/smartctl_exporter Cleanup obsolete yaml config 2022-10-03 17:35:37 +02:00
scripts Refactor exporter config (#68) 2022-10-03 11:16:00 +02:00
systemd systemd service 2019-08-15 00:04:32 +03:00
.gitignore Fix Dockerfile (#53) 2022-08-08 17:03:53 +02:00
.golangci.yml Refactor exporter config (#68) 2022-10-03 11:16:00 +02:00
.promu.yml Update build for prometheus-community 2022-06-17 12:04:48 +02:00
.yamllint Update build for prometheus-community 2022-06-17 12:04:48 +02:00
CHANGELOG.md Release 0.9.0 2022-10-20 18:22:58 +07:00
CODE_OF_CONDUCT.md Update common Prometheus files 2022-06-17 19:51:12 +00:00
Dockerfile Drop arm64 Docker image 2022-10-05 14:06:48 +02:00
EXAMPLE.md Added disk form_factor meta label 2022-10-17 14:28:05 +07:00
LICENSE Initial commit 2019-08-14 23:28:21 +03:00
Makefile Drop arm64 Docker image 2022-10-05 14:06:48 +02:00
Makefile.common Update common Prometheus files (#70) 2022-09-20 20:14:46 +02:00
README.md Refactor exporter config (#68) 2022-10-03 11:16:00 +02:00
SECURITY.md Update common Prometheus files 2022-06-17 19:51:12 +00:00
VERSION Release 0.9.0 2022-10-20 18:22:58 +07:00
collect_fake_json.sh Parsing smartctl error code; parsing resulting json for smartctl errors; docker moved to subfolder 2020-10-30 00:35:49 +03:00
gjsonext.go Release 0.7.0 (#50) 2022-08-05 03:37:13 +02:00
go.mod update to exporter-toolkit v0.8.1 2022-10-22 14:00:37 -04:00
go.sum update to exporter-toolkit v0.8.1 2022-10-22 14:00:37 -04:00
main.go Remove useless error message 2022-11-06 11:56:41 +01:00
metrics.go Added disk form_factor meta label 2022-10-17 14:28:05 +07:00
readjson.go Remove useless error message 2022-11-06 11:56:41 +01:00
smartctl.go Merge pull request #28 from lahwaacz/master 2022-10-20 11:42:19 +01:00
smartctlinfo.go Release 0.7.0 (#50) 2022-08-05 03:37:13 +02:00

README.md

CircleCI Container Repository on Quay

smartctl_exporter

Export smartctl statistics to prometheus

Example output you can show in EXAMPLE.md

Need more?

If you need additional metrics - contact me :) Create a feature request, describe the metric that you would like to have and attach exported from smartctl json file

Requirements

smartmontools >= 7.0, because export to json released in 7.0

Configuration

Command line options

The exporter will scan the system for available devices if no --smartctl.device flags are used.

usage: smartctl_exporter [<flags>]

Flags:
  -h, --help                   Show context-sensitive help (also try --help-long and --help-man).
      --smartctl.path="/usr/sbin/smartctl"  
                               The path to the smartctl binary
      --smartctl.interval=60s  The interval between smarctl polls
      --smartctl.device=SMARTCTL.DEVICE ...  
                               The device to monitor (repeatable)
      --web.listen-address=":9633"  
                               Address to listen on for web interface and telemetry
      --web.telemetry-path="/metrics"  
                               Path under which to expose metrics
      --web.config.file=""     [EXPERIMENTAL] Path to configuration file that can enable TLS or authentication.
      --log.level=info         Only log messages with the given severity or above. One of: [debug, info, warn,
                               error]
      --log.format=logfmt      Output format of log messages. One of: [logfmt, json]
      --version                Show application version.

TLS and basic authentication

This 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.