![]() ![]() |
crusader |
Subversion Repositories: |
Compare with Previous - Blame - Download
#!/bin/bash### 2005-10-27/Libor pridano prehazovani na WiFi zalohu pri signalu < 300##stat_dir="/var/statistiky/crusader"logfile="$stat_dir/crusader.log"mkdir -p $stat_dirconfig_file=/opt/statistiky/collect_crusader.confscript_set_main=/opt/statistiky/crusader_set_main.shscript_set_backup=/opt/statistiky/crusader_set_backup.shfunction Log()# $1 ... message{timenow=`date +"%Y-%m-%d %T"`echo "$timenow $1"echo "$timenow $1" >>$logfile}Log "Crusader start ====="Log "Using config file: $config_file"if [ ! -f $config_file ]thenLog "Missing config file $config_file, exiting."exit 1;fiif [ ! -x $script_set_main ]; thenLog "Script set up main is not executable: $script_set_main"exit 1;fiif [ ! -x $script_set_backup ]; thenLog "Script set up main is not executable: $script_set_backup"exit 1;ficd $stat_dirfunction create()# $1 ... netdevice{local file=$1Log "Creating RRD archive $file"# step = 5s# za posledni 2,5 hodiny chceme vsechny PDP => 2,5 * 3600 / 5 = 1800 hodnot/radku# 20s ~ agregace ze ctyr hodnot (PDP)# za poslednich 10 hodin chceme 20s udaje => 10*3600/20 = 1800 generaci/radku# za poslednich 30 hodin chceme 60s udaje => 30*3600/60 = 1800 generaci/radku# 5 minut = 12 PDP za minutu * 5 minut = 60 PDP# za posledni tyden (9dni) chceme 5minutove udaje => 12*24*9 = 2592 radku (rows)# 20min ~ agregace z 240 PDP# za posledni mesic (38dni) chceme 20minutove useky => 3*24*38 = 2736 radku# dve hodiny ~ 1440 PDP# za posledni rok chceme dvouhodinove useky => 12*400 = 4800 radkurrdtool create ${file}.rrd --step 5 --start `date +%s` \DS:rss_avg:GAUGE:10:0:999 \DS:rss_min:GAUGE:10:0:999 \DS:rss_max:GAUGE:10:0:999 \RRA:AVERAGE:0.7:1:1800 \RRA:MAX:0.7:1:1800 \RRA:MIN:0.7:1:1800 \RRA:AVERAGE:0.7:4:2880 \RRA:MAX:0.7:4:2880 \RRA:MIN:0.7:4:2880 \RRA:AVERAGE:0.7:12:1800 \RRA:MAX:0.7:12:1800 \RRA:MIN:0.7:12:1800 \RRA:AVERAGE:0.7:60:2592 \RRA:MAX:0.7:60:2592 \RRA:MIN:0.7:60:2592 \RRA:AVERAGE:0.7:240:2736 \RRA:MAX:0.7:240:2736 \RRA:MIN:0.7:240:2736 \RRA:AVERAGE:0.7:1440:4800 \RRA:MAX:0.7:1440:4800 \RRA:MIN:0.7:1440:4800}function wait_to()# $1 date for waiting to{local time_now=`date +%s`;while [ $time_now -lt $1 ]dotime_now=`date +%s`sleep 1;done}function activate_wifi(){$script_set_backup# ip route del default# ip route add default via 10.23.13.1echo "Activated WiFi backup"}function activate_fso(){$script_set_main# ip route del default# ip route add default via 10.23.192.53echo "Activated FSO primary link"}rss_offset=75# kolikrat byl signal nizsi nez rss_low_threshold opakovane v rade po soberss_low_count=0# pocet detekovanych slabych signalu v rade, kdy se prepoji inet na zalohurss_low_count_down=3# pokud sila signalu klesne pod threshold je indikovana jako slaby signallet rss_low_threshold=300+$rss_offset# kolikrat byl signal vyssi nez rss_good_threshold opakovane v rade po soberss_good_count=0# pocet detekovanych dobrych signalu v rade, kdy se prepoji inet zpet na Crusaderrss_good_count_up=12# pokud sila signalu stoupne nad threshold je indikovana jako dobry signallet rss_good_threshold=350+$rss_offset# stav sily signalu, muze byt 'low' nebo 'good'# zaciname s 'good' protoze prepnuti good->low je rychlejsi a taky startup skripty# pocitaji s optickou linkou, WiFi je zaloharss_status="good"rss_status_last="good"Log "RSS offset = $rss_offset"Log "RSS low threshold = $rss_low_threshold"Log "RSS good threshold = $rss_good_threshold"function rss_check_status()# $1 ... jmeno rusaderu (napr. crusader0)# $2 je sila signalu RSS{local name=$1local rss=$2if [ $rss -ge $rss_low_threshold ]; thenecho "RSS($rss) >= low_threshold ($rss_low_threshold), erasing rss_low_count"rss_low_count="0"fiif [ $rss -le $rss_good_threshold ]; thenecho "RSS($rss) <= good_threshold ($rss_good_threshold), erasing rss_good_count"rss_good_count="0"fiif [ "$rss_status" == "good" ] && [ $rss -lt $rss_low_threshold ]; thenlet rss_low_count+=1echo "RSS($rss) < low_threshold ($rss_low_threshold), increasing rss_low_count to $rss_low_count"fiif [ "$rss_status" == "low" ] && [ $rss -gt $rss_good_threshold ]; thenlet rss_good_count+=1echo "RSS($rss) > good_threshold ($rss_good_threshold), increasing rss_good_count to $rss_good_count"fiif [ "$rss_status" == "good" ] && [ $rss_low_count -ge $rss_low_count_down ]; thenecho "FSO link goes down"rss_status="low"activate_wifiLog "$name goes down, activating WiFi backup (RSS $rss)"fiif [ "$rss_status" == "low" ] && [ $rss_good_count -ge $rss_good_count_up ]; thenecho "FSO link goes up"rss_status="good"activate_fsoLog "$name goes up (RSS $rss)"fi}start_time=`date +%s`interval=$(( $start_time / 5 * 5 + 5 ))while [ true ] ; do. ${config_file}device=${DEVICE[0]}name=${NAME[0]}0rrdfile=$nameif [ ! -f $rrdfile.rrd ] ; thencreate $rrdfilefisoucet_rss="0"rss_min="1000" # ma to jen tri cifry, tj. max 999 => 1000 je vic nez maximumrss_max="0"pocet="0"read rss <${device} # pouze synchronizace, holt o jeden radek prijdemetime_now=`date +%s`while [ $time_now -lt $interval ]; do # cekame na zacatek dalsiho intervalutime_now=`date +%s`read -t 1 rss rest <${device} # tady cteme# echo "rss: '$rss' and the rest of line: '$rest'"test $rss -ge 0 2>/dev/null # slouzi k otestovani, ze rss obsahuje numerickou hodnoruif [ $? -lt 2 ] # pokud vyjde 2, pak to neni cislo a test selhalthensoucet_rss=$(( $soucet_rss + $rss ))pocet=$(( $pocet + 1 ))if [ $rss -lt $rss_min ]; thenrss_min=$rssfiif [ $rss -gt $rss_max ]; thenrss_max=$rssfifidoneif [ $pocet -gt 0 ]thenprumer=`echo "${soucet_rss}/${pocet}" | bc -l`echo "prumer: $prumer min: $rss_min max: $rss_max"rrdtool update $rrdfile.rrd -t rss_avg:rss_min:rss_max $interval:$prumer:$rss_min:$rss_maxprumer=`echo $prumer | cut -d '.' -f 1`rss_check_status $name $prumerelseecho "NaN"rrdtool update $rrdfile.rrd -t rss_avg:rss_min:rss_max $interval:U:U:Urss_check_status $name 0fiinterval=$(( $interval + 5 ))done