ファイルst.txt:
"succeeded" "test" "2018-03-30T13:42:12Z" "2018-03-30T13:42:21Z"
最新のRundeckjobステータスを返すスクリプトがあります。
curl -s -H "Accept: application/json" -X GET "http://localhost:4440/api/20/project/Windows-AD/executions?authtoken=r50onM4kXzZ7DhhAN6Fe2rwwxuAhF0IG" | python -m json.tool > 1.json
jq -r '.|[.executions[] | select(.job.name != null)] | sort_by(.id) | reverse | .[0] | [.status, .job.name, ."date-started".date, ."date-ended".date] | @csv' 1.json > 1.csv
sed 's/,/ /g' 1.csv>st.txt
while read status name startdate enddate; do
case "$status" in
"\"aborted\"")
echo -1
;;
"\"failed\"")
echo -1 + $name
;;
"\"succeeded\"")
echo 0
;;
*) echo 0 + $name
esac
exit 0
done<st.txt
2018-03-30T13:42:12Z" "2018-03-30T13:42:21Z"
$start と $enddate(" ) を比較し、差が 5 分を超える場合は、"長すぎる"別の終了を追加する方法
答え1
次のように開始/終了日を変換して比較できます。
startdate=${startdate//\"/}
stime=$(date -d "${startdate/T/ }" +%s)
enddate=${enddate//\"/}
etime=$(date -d "${enddate/T/ }" +%s)
let elapsed=etime-stime
[ $elapsed -gt 300 ] && echo "taking too long"
答え2
GNU日付は数学的計算を直接(秒単位)実行できます。
POSIXスクリプト
#!/bin/sh
sd='"2018-03-30T13:42:12Z"'
ed='"2018-03-30T13:42:21Z"'
sd=${sd#\"}; sd=${sd%\"} # Remove double quotes.
ed=${ed#\"}; ed=${ed%\"}
ep=$(date -d @0) # Epoch date (anchor).
ss=$(date -d "$sd" +%s) # Start time.
es=$(date -d "$ed" +%s) # End time.
elapsed=$(date -d "$ep - ${ss}sec + ${es}sec" +%s)
if [ "$elapsed" -gt 300 ]]; then
echo "taking too long"
fi