-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcron-node-check.sh
executable file
·39 lines (30 loc) · 1.21 KB
/
cron-node-check.sh
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
#!/bin/bash
sinfo_check=$(sinfo | grep -iE "drain|down")
#mail_domain=$(curl -s https://ipinfo.io/hostname)
mail_domain=$(host $(curl -s http://169.254.169.254/latest/meta-data/public-ipv4) | sed 's/.*pointer \(.*\)./\1/')
email_addr=""
try_count=0
declare -i try_count
until [[ -n $mail_domain || $try_count -ge 10 ]];
do
sleep 3
mail_domain=$(curl -s https://ipinfo.io/hostname)
try_count=$try_count+1
echo $mail_domain, $try_count
done
if [[ $try_count -ge 10 ]]; then
echo "failed to get domain name!"
exit 1
fi
if [[ -n $sinfo_check ]]; then
echo $sinfo_check | mailx -r "node-check@$mail_domain" -s "NODE IN BAD STATE - $mail_domain" $email_addr
# echo "$sinfo_check mailx -r "node-check@$mail_domain" -s "NODE IN BAD STATE - $mail_domain" $email_addr" # TESTING LINE
fi
#Check for ACTIVE nodes without running/cf/cg jobs
squeue_check=$(squeue -h -t CF,CG,R)
#source the openrc.sh for instance check
$(sudo cat /etc/slurm/openrc.sh)
compute_node_check=$(openstack server list | awk '/compute/ && /ACTIVE/')
if [[ -n $compute_node_check && -z $squeue_check ]]; then
echo $compute_node_check $squeue_check | mailx -r "node-check@$mail_domain" -s "NODE IN ACTIVE STATE WITHOUT JOBS- $mail_domain" $email_addr
fi