mirror of
https://github.com/prometheus-community/smartctl_exporter.git
synced 2024-12-21 02:21:55 +01:00
Merge pull request #159 from NiceGuyIT/issue-158
Fix #158: collect_fake_json.sh
This commit is contained in:
commit
25f25810fc
1 changed files with 22 additions and 3 deletions
|
@ -1,6 +1,25 @@
|
|||
#! /bin/bash
|
||||
|
||||
for device in $(smartctl --scan | awk '{ print $1}')
|
||||
do
|
||||
smartctl --json --xall $device | jq > debug/$(basename $device).json
|
||||
script_dir=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
|
||||
|
||||
# The original script used --xall but that doesn't work
|
||||
# This matches the command in readSMARTctl()
|
||||
smartctl_args="--json --info --health --attributes --tolerance=verypermissive --nocheck=standby --format=brief --log=error"
|
||||
|
||||
[[ ! -d "${script_dir}/debug" ]] && mkdir --parents "${script_dir}/debug"
|
||||
|
||||
if command -v jq >/dev/null; then
|
||||
devices=$(smartctl --scan --json | jq --raw-output '.devices[].name')
|
||||
elif command -v yq >/dev/null; then
|
||||
devices=$(smartctl --scan --json | yq --unwrapScalar '.devices[].name')
|
||||
elif command -v awk >/dev/null; then
|
||||
devices=$(smartctl --scan | awk '{ print($1) }')
|
||||
else
|
||||
devices=$(smartctl --scan | cut -d ' ' -f 1)
|
||||
fi
|
||||
|
||||
for device in $devices; do
|
||||
echo "Collecting data for '${device}'"
|
||||
# shellcheck disable=SC2086
|
||||
sudo smartctl $smartctl_args "${device}" > "${script_dir}/debug/$(basename "${device}").json"
|
||||
done
|
||||
|
|
Loading…
Reference in a new issue