mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	Commit review 9586
Signed-off-by: Hugo Trippaers <htrippaers@schubergphilis.com>
This commit is contained in:
		
							parent
							
								
									6675d2c1a3
								
							
						
					
					
						commit
						c30da35811
					
				| @ -19,7 +19,7 @@ | ||||
| #set -x | ||||
| 
 | ||||
| usage() { | ||||
|   printf "Usage: %s [uuid of this host] [interval in seconds]\n" $(basename $0) >&2 | ||||
|   printf "Usage: %s [uuid of this host] [timeout in seconds] [interval in seconds]\n" $(basename $0) >&2 | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| @ -33,10 +33,24 @@ if [ -z $2 ]; then | ||||
|   exit 3 | ||||
| fi | ||||
| 
 | ||||
| if [ ! -z $3 ]; then | ||||
|   interval=$3 | ||||
| else | ||||
|   interval=10 | ||||
| fi | ||||
| 
 | ||||
| if [ $interval -gt $2 ]; then | ||||
|   usage | ||||
|   exit 3 | ||||
| fi | ||||
| 
 | ||||
| file=/opt/xensource/bin/heartbeat | ||||
| while true  | ||||
| maxtries=$(($2 / $interval)) | ||||
| tries=1 | ||||
| 
 | ||||
| while [ $tries -le $maxtries ] | ||||
| do | ||||
|   sleep $2 | ||||
|   sleep $interval | ||||
| 
 | ||||
|   if [ ! -f $file  ] | ||||
|   then | ||||
| @ -51,13 +65,17 @@ do | ||||
|       hb=$dir/hb-$1 | ||||
|       date +%s | dd of=$hb count=100 bs=1 2>/dev/null | ||||
|       if [ $? -ne 0 ]; then | ||||
|           /usr/bin/logger -t heartbeat "Problem with $hb" | ||||
|           reboot -f | ||||
|           /usr/bin/logger -t heartbeat "Potential problem with $hb: not reachable since $(($tries * $interval)) seconds" | ||||
|           tries=$(($tries + 1)) | ||||
|       else | ||||
|           tries=1 | ||||
|       fi | ||||
|     else | ||||
|       /usr/bin/logger -t heartbeat "Heartbeat dir not found for $dir" | ||||
|       sed -i /${dir##/*/}/d $file | ||||
|     fi | ||||
|   done | ||||
| 
 | ||||
|   # for nfs | ||||
|   dirs=$(cat $file | grep sr-mount) | ||||
|   for dir in $dirs | ||||
| @ -67,13 +85,17 @@ do | ||||
|       hb=$dir/hb-$1 | ||||
|       date +%s | dd of=$hb count=100 bs=1 2>/dev/null | ||||
|       if [ $? -ne 0 ]; then | ||||
|           /usr/bin/logger -t heartbeat "Problem with $hb" | ||||
|           reboot -f | ||||
|           /usr/bin/logger -t heartbeat "Potential problem with $hb: not reachable since $(($tries * $interval)) seconds" | ||||
|           tries=$(($tries + 1)) | ||||
|       else | ||||
|           tries=1 | ||||
|       fi | ||||
|     else | ||||
|       /usr/bin/logger -t heartbeat "Heartbeat mount not found for $dir" | ||||
|       sed -i /${dir##/*/}/d $file | ||||
|     fi | ||||
|   done | ||||
| 
 | ||||
| done | ||||
| 
 | ||||
| /usr/bin/logger -t heartbeat "Problem with $hb: not reachable for $2 seconds, rebooting system!" | ||||
| reboot -f | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user