#!/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_dir config_file=/opt/statistiky/collect_crusader.conf script_set_main=/opt/statistiky/crusader_set_main.sh script_set_backup=/opt/statistiky/crusader_set_backup.sh function 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 ] then Log "Missing config file $config_file, exiting." exit 1; fi if [ ! -x $script_set_main ]; then Log "Script set up main is not executable: $script_set_main" exit 1; fi if [ ! -x $script_set_backup ]; then Log "Script set up main is not executable: $script_set_backup" exit 1; fi cd $stat_dir function create() # $1 ... netdevice { local file=$1 Log "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 radku rrdtool 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 ] do time_now=`date +%s` sleep 1; done } function activate_wifi() { $script_set_backup # ip route del default # ip route add default via 10.23.13.1 echo "Activated WiFi backup" } function activate_fso() { $script_set_main # ip route del default # ip route add default via 10.23.192.53 echo "Activated FSO primary link" } rss_offset=75 # kolikrat byl signal nizsi nez rss_low_threshold opakovane v rade po sobe rss_low_count=0 # pocet detekovanych slabych signalu v rade, kdy se prepoji inet na zalohu rss_low_count_down=3 # pokud sila signalu klesne pod threshold je indikovana jako slaby signal let rss_low_threshold=300+$rss_offset # kolikrat byl signal vyssi nez rss_good_threshold opakovane v rade po sobe rss_good_count=0 # pocet detekovanych dobrych signalu v rade, kdy se prepoji inet zpet na Crusader rss_good_count_up=12 # pokud sila signalu stoupne nad threshold je indikovana jako dobry signal let 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 zaloha rss_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=$1 local rss=$2 if [ $rss -ge $rss_low_threshold ]; then echo "RSS($rss) >= low_threshold ($rss_low_threshold), erasing rss_low_count" rss_low_count="0" fi if [ $rss -le $rss_good_threshold ]; then echo "RSS($rss) <= good_threshold ($rss_good_threshold), erasing rss_good_count" rss_good_count="0" fi if [ "$rss_status" == "good" ] && [ $rss -lt $rss_low_threshold ]; then let rss_low_count+=1 echo "RSS($rss) < low_threshold ($rss_low_threshold), increasing rss_low_count to $rss_low_count" fi if [ "$rss_status" == "low" ] && [ $rss -gt $rss_good_threshold ]; then let rss_good_count+=1 echo "RSS($rss) > good_threshold ($rss_good_threshold), increasing rss_good_count to $rss_good_count" fi if [ "$rss_status" == "good" ] && [ $rss_low_count -ge $rss_low_count_down ]; then echo "FSO link goes down" rss_status="low" activate_wifi Log "$name goes down, activating WiFi backup (RSS $rss)" fi if [ "$rss_status" == "low" ] && [ $rss_good_count -ge $rss_good_count_up ]; then echo "FSO link goes up" rss_status="good" activate_fso Log "$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]}0 rrdfile=$name if [ ! -f $rrdfile.rrd ] ; then create $rrdfile fi soucet_rss="0" rss_min="1000" # ma to jen tri cifry, tj. max 999 => 1000 je vic nez maximum rss_max="0" pocet="0" read rss <${device} # pouze synchronizace, holt o jeden radek prijdeme time_now=`date +%s` while [ $time_now -lt $interval ]; do # cekame na zacatek dalsiho intervalu time_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 hodnoru if [ $? -lt 2 ] # pokud vyjde 2, pak to neni cislo a test selhal then soucet_rss=$(( $soucet_rss + $rss )) pocet=$(( $pocet + 1 )) if [ $rss -lt $rss_min ]; then rss_min=$rss fi if [ $rss -gt $rss_max ]; then rss_max=$rss fi fi done if [ $pocet -gt 0 ] then prumer=`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_max prumer=`echo $prumer | cut -d '.' -f 1` rss_check_status $name $prumer else echo "NaN" rrdtool update $rrdfile.rrd -t rss_avg:rss_min:rss_max $interval:U:U:U rss_check_status $name 0 fi interval=$(( $interval + 5 )) done WebSVN - crusader - Blame - Rev 1 - /trunk/statistiky/opt/statistiky/archiv/collect_crusader.sh.20051102
  jablonka.czprosek.czf

crusader

Subversion Repositories:
[/] [trunk/] [statistiky/] [opt/] [statistiky/] [archiv/] [collect_crusader.sh.20051102] - Blame information for rev 1

 

Line No. Rev Author Line

Powered by WebSVN 2.2.1