forked from cyclingzealot/dumuzid
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webOnline.bash
executable file
·122 lines (86 loc) · 2.56 KB
/
webOnline.bash
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#!/usr/bin/env bash
START=$(date +%s.%N)
arg1=${1:-''}
TH=20
if [[ $arg1 == '--help' || $arg1 == '-h' ]]; then
echo "Usage: $0 [\$thresholdTimeoutSeconds]"
echo "The first argument is the timeout in seconds. Defaults to ${TH} seconds"
exit 0
fi
TH=${1:-20}
#exit when command fails (use || true when a command can fail)
set -o errexit
#exit when your script tries to use undeclared variables
set -o nounset
# in scripts to catch mysqldump fails
set -o pipefail
# Resolve first directory of script
PRG="$BASH_SOURCE"
progname=`basename "$BASH_SOURCE"`
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG=`dirname "$PRG"`"/$link"
fi
done
__dir=$(dirname "$PRG")
# Set magic variables for current file & dir
__root="$(cd "$(dirname "${__dir}")" && pwd)" # Dir of the dir of the script
__file="${__dir}/$(basename "${BASH_SOURCE[0]}")" # Full path of the script
__base="$(basename ${__file})" # Name of the script
ts=`date +'%Y%m%d-%H%M%S'`
ds=`date +'%Y%m%d'`
pid=`ps -ef | grep ${__base} | grep -v 'vi ' | head -n1 | awk ' {print $2;} '`
formerDir=`pwd`
# If you require named arguments, see
# http://stackoverflow.com/questions/192249/how-do-i-parse-command-line-arguments-in-bash
#Set the config file
configFile="$HOME/.${__base}.conf"
#=== END Unique instance ============================================
#Capture everything to log
mkdir -p ~/log
log=~/log/$__base-${ts}.log
exec > >(tee -a $log)
exec 2> >(tee -a $log >&2)
touch $log
chmod 600 $log
#Check that the config file exists
if [[ ! -f "$configFile" ]] ; then
echo "I need a file at $configFile with urls to test (as many as you like)"
fi
export DISPLAY=:0
echo; echo; echo;
### BEGIN SCRIPT ###############################################################
#(a.k.a set -x) to trace what gets executed
set -o xtrace
sendAlert=0
body=''
if [[ ! -f $configFile ]]; then
sendAlert=1
body="No pages to test for $__base"
fi
for page in `cat $configFile | sort | uniq | sort -R `; do
START=$(date +%s.%N)
connect=false
attempts=0
set -x
while [ $attempts -lt 3 ] && ! $connect ; do
if ! curl -k -I -fs --max-time $TH $page > /dev/null ; then
let "attempts++" || true
else
connect=true
fi
sleep 1
done
if ! $connect ; then
END=$(date +%s.%N)
DIFF=$(echo "$END - $START" | bc)
sendAlert=1
body="$page not loading or took $DIFF to load"
fi
done
echo $body
exit $sendAlert