
ストレージ デバイスからディスク モニタリングを取得しようとしています。デバイスをクエリして出力を取得できます。
例: --vol_list
dr_prdoracle_bkup 83%
dr_test 6%
infra_backup 3%
logs 28%
oem_shared 2%
prd_backup 51%
rhev_export 24%
ss_backup 2%
ss_data 23%
ここでは使用率に応じて警告を発しようとしています。ここでは50%で警告、70%で重大を作成しようとしています。
しきい値はコマンドラインで解析されます
WarnSpace=$2
CritSpace=$2
ST_OK=0
ST_WR=1
ST_CR=2
ST_UK=3
for line in $(cat "vol_list"); do
SpaceUsed=`echo ${line}|awk '{print $2}'|sed 's/%//'`
volume=`echo ${line}|awk '{print $1}'`
if [ -n "$WarnSpace" -a -n "$CritSpace" ]
then
if [ "$SpaceUsed" -ge "$WarnSpace" -a "$SpaceUsed" -le "$CritSpace" ]
then
#echo "WARNING - ${output} | ${perfdata}"
echo "WARNING; $volume: total $SpaceUsed"%""
exit $ST_WR
elif [ "$SpaceUsed" -ge "$CritSpace" ]
then
#echo "CRITICAL - ${output} | ${perfdata}"
echo "CRITICAL; $volume: total $SpaceUsed"%""
exit $ST_CR
fi
done
終了ステータスを使用するとループから抜け出します。例:
./purefs_check.sh -w 50 -c 70
WARNING; dev_client: total 67%
終了コードを削除すると期待どおりの結果が得られます
WARNING; dev_client: total 67%
CRITICAL; dev_data: total 89%
CRITICAL; dev_vendor: total 99%
WARNING; dr_client: total 54%
CRITICAL; dr_prdoracle_bkup: total 78%
WARNING; prd_backup: total 51%
必要なのは、ループを終了し、終了ステータスとして警告の場合は 1、重大の場合は 2 を返すことです。
終了コードは 1 つだけ、エントリは 1 つ以上が望ましいです。
そこで私が見たいのは
./purefs_check.sh -w 50 -c 70 |grep WAR ;echo $?
WARNING; dev_client: total 67%
WARNING; dr_client: total 54%
WARNING; prd_backup: total 51%
1
CRITICAL; dev_data: total 89%
CRITICAL; dev_vendor: total 99%
CRITICAL; dr_prdoracle_bkup: total 78%
2
ご協力いただければ幸いです。
答え1
exit
シェルを終了します、すぐに終了します。後で使用する終了コードを設定する場合は、フラグを設定するか、終了コードを手動で保存する必要があります。
#!/bin/bash
warns=""
crits=""
for x in ...; do
if warning_condition; then
warns=1 # or keep a count with warns=$((warns + 1))
elif critical_condition; then
crits=1
fi
done
[ "$crits" ] && exit 2
[ "$warns" ] && exit 1
あるいは
#!/bin/bash
exit_code=0
set_exit_code() {
# save the greatest given exit code
[ "$1" -gt "$exit_code" ] && exit_code=$1
}
for x in ...; do
if warning_condition; then
set_exit_code 1
elif critical_condition; then
set_exit_code 2
fi
done
exit "$exit_code"
これに関しては…
$ ./purefs_check.sh -w 50 -c 70 |grep WAR ;echo $?
$?
は の終了コードを保持するため、動作しませんgrep
。 これを使用して を含む出力行があったかどうかを調べることができますWAR
が、それが必要なことではないと思います。
出力警告を最初にソートしたい場合は、警告と重大な警告を配列に収集し、最後に出力する必要があります。または、データを 2 回調べて、最初に警告を探し、その後に重大な警告のみを探します。
答え2
あなたが持っている:
WarnSpace=$2
CritSpace=$2
そしてスクリプトを次のように呼び出します
./purefs_check.sh -w 50 -c 70
したがって、CritSpace 値は 50 になります。
オプションをまったく処理していません。代わりに次の操作を実行してください。
#!/bin/bash
ST_OK=0
ST_WR=1
ST_CR=2
ST_UK=3
while getopts :w:c: opt; do
case $opt in
w) WarnSpace=$OPTARG ;;
c) CritSpace=$OPTARG ;;
*) echo "Warning: unknown option -$opt: ignoring it" >&2 ;;
esac
done
shift $((OPTIND - 1))
if [[ -z "$WarnSpace" ]]; then
echo "Error: specify a warning threshold with -w" >&2
exit $ST_UK
elif [[ -z "$CritSpace" ]]; then
echo "Error: specify a critical threshold with -c" >&2
exit $ST_UK
fi
warn=0
crit=0
while read -r volume SpaceUsed; do
SpaceUsed=${SpaceUsed//[^[:digit:]]/} # delete all non-digits
if (( SpaceUsed >= CritSpace )); then
echo "CRITICAL; $volume: total $SpaceUsed"
((crit++))
elif (( SpaceUsed >= WarnSpace )); then
echo "WARNING; $volume: total $SpaceUsed"
((warn++))
fi
done < vol_list
((crit > 0)) && exit $ST_CR
((warn > 0)) && exit $ST_WR
exit $ST_OK