-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmonitorInternetConnectionBackground.bash
executable file
·75 lines (53 loc) · 1.79 KB
/
monitorInternetConnectionBackground.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
#!/usr/bin/env bash
START=$(date +%s.%N)
#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
#(a.k.a set -x) to trace what gets executed
set -o xtrace
# in scripts to catch mysqldump fails
set -o pipefail
# Set magic variables for current file & dir
__dir="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
__root="$(cd "$(dirname "${__dir}")" && pwd)" # <-- change this
__file="${__dir}/$(basename "${BASH_SOURCE[0]}")"
__base="$(basename ${__file})"
ts=`date +'%Y%m%d-%H%M%S'`
#Set the config file
configFile="$HOME/.binJlam/templateConfig"
#Ensure only one copy is running
pidfile=$HOME/.${__base}.pid
if [ -f ${pidfile} ]; then
#verify if the process is actually still running under this pid
oldpid=`cat ${pidfile}`
result=`ps -ef | grep ${oldpid} | grep ${__base} || true`
if [ -n "${result}" ]; then
echo "Script already running! Exiting"
exit 255
fi
fi
#grab pid of this process and update the pid file with it
pid=`ps -ef | grep ${__base} | grep -v 'vi ' | head -n1 | awk ' {print $2;} '`
echo ${pid} > ${pidfile}
#Capture everything to 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 ..."
# exit 1
#fi
echo Begin `date` .....
### BEGIN SCRIPT ###############################################################
ping -i 2 credil.org | perl -nle 'print scalar(localtime), " ", $_'
### END SCIPT ##################################################################
END=$(date +%s.%N)
DIFF=$(echo "$END - $START" | bc)
echo Done. `date` - $DIFF seconds
if [ -f ${pidfile} ]; then
rm ${pidfile}
fi