特定の終了ステータスを探している場合、forループの最初のインスタンスは終了します。

特定の終了ステータスを探している場合、forループの最初のインスタンスは終了します。

ストレージ デバイスからディスク モニタリングを取得しようとしています。デバイスをクエリして出力を取得できます。

例: --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

関連情報