![]() ![]() |
crusader |
Subversion Repositories: |
Compare with Previous - Blame - Download
#!/bin/bash### 2008-06-07/Libor Zacinam pokusovat s adaptaci pro Crusader Aggregator 100M## 2006-11-22/Libor Predelano cteni RSS pomoci nove aplikace napsane v C pro snizeni# zateze CPU, ktera na VIA C3 800MHz ve stavajici podobe dosahovala# az 100%.## 2005-11-27/Libor Predelano cteni seriaku. Ted si ho otevre jako filedescriptor# a cte z nej jako ze souboru. Na Marvinovi se tim (snad) uplne# odstranily chly do nuly, ktere byly nejspis zpusobeny# rychlosti (pomalosti) Marvina. (800MHz VIA C3)# 2005-11-02/Libor konfiguracni skripty na prehazovani primarni FSO <-> backup WiFi# logovani do /var/statistiky/crusader/crusader.log# bash3, nevim proc, ale na Marvinovi mi to s dvojkou nechodilo kvuliva# porovnavani desetinnych cisel pomoci if [ $neco -le $rss ]...# 2005-10-27/Libor pridano prehazovani na WiFi zalohu pri signalu < 300##PATH=$PATH:/opt/statistiky/binif [ $# -eq 1 ]; thencrusader_number=$1fiif [ $# -gt 1 ]; thenecho "ERROR: more than 1 option" >&2fiif [ $# -lt 1 ]; thencrusader_number=0fistat_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 "LOG: $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}# zastarala: ted cekame pomoci crusader_read_rssfunction 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_backup(){$script_set_backupecho "Activated WiFi backup"}function activate_fso(){$script_set_mainecho "Activated FSO primary link"}function read_remote_status(){remote_rss_status=`grep ^RSS: /var/statistiky/crusader/remote_site_status | awk '{ print $2;}'`echo "Remote RSS status: $remote_rss_status"}function write_status_to_remote(){Log " Writing status (RSS: $rss_status) to remote side"ssh libor@10.23.64.169 "echo \"RSS: $rss_status\" >/var/statistiky/crusader/remote_site_status"}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_counter_go_backup ]; thenecho "RSS goes down"rss_status="low"Log "Crusader $crusader_number: goes down, RSS: low ($rss)"write_status_to_remotefiif [ "$rss_status" == "low" ] && [ $rss_good_count -ge $rss_good_counter_go_main ]; thenecho "RSS goes up"rss_status="good"Log "Crusader $crusader_number: goes up, RSS: good ($rss)"write_status_to_remotefiif [ "$link_status" == "FSO" ] && [ "$rss_status" == "low" ]thenLog "Link to backup"activate_backuplink_status="backup"fiif [ "$link_status" == "backup" ] && [ "$rss_status" == "good" ] && [ "$remote_rss_status" == "good" ]thenLog "Link to FSO"activate_fsolink_status="FSO"firead_remote_statusif [ "$link_status" == "FSO" ] && [ "$remote_rss_status" == "low" ]thenLog "Link to backup"activate_backuplink_status="backup"write_status_to_remotefi}# Pocatecni nastaveni linky FSO/backupfunction setup_initial_link_status(){if [ $rss_avg -gt $rss_good_threshold ]; thenrss_status="good"rss_status_last="good"link_status="unknown"elserss_status="low"rss_status_last="low"link_status="unknown"fiwrite_status_to_remoteread_remote_statusif [ "$rss_status" == "good" ] && [ "$remote_rss_status" == "good" ]thenLog "Link to FSO"activate_fsolink_status="FSO"elseLog "Link to backup"activate_backuplink_status="backup"fi}function load_config(){. ${config_file}rss_low_threshold=${RSS_LOW_THRESHOLD[$crusader_number]}rss_good_threshold=${RSS_GOOD_THRESHOLD[$crusader_number]}rss_low_counter_go_backup=${RSS_LOW_COUNTER_TO_GO_BACKUP[$crusader_number]}rss_good_counter_go_main=${RSS_GOOD_COUNTER_TO_GO_MAIN[$crusader_number]}device=${DEVICE[$crusader_number]}name=${NAME[$crusader_number]}${crusader_number}}print_config(){Log "Crusader $crusader_number"Log " RSS low threshold = $rss_low_threshold"Log " RSS good threshold = $rss_good_threshold"Log " RSS low counter go backup = $rss_low_counter_go_backup"Log " RSS good counter go main = $rss_good_counter_go_main"Log " Seriak: $device"}# Inicializaceload_configprint_configj=0rv=2rss_line=`crusader_read_rss ${device} +2 2>/dev/null`rss_avg=`echo $rss_line | awk '{ print $2; }'`if [ -z "$rss_avg" ]; thenrss_avg="0"fiLog " Sila signalu pri startu (RSS): $rss_avg"# Prvotni nastaveni linky pred hlavni smyckou#setup_initial_link_status# kolikrat byl signal nizsi nez rss_low_threshold opakovane v rade po soberss_low_counter=0# kolikrat byl signal vyssi nez rss_good_threshold opakovane v rade po soberss_good_counter=0start_time=`date +%s`interval=$(( $start_time / 5 * 5 + 5 ))# Hlavni smyckawhile [ true ] ; doload_configrrdfile=${name}if [ ! -f $rrdfile.rrd ] ; thencreate $rrdfilefirss_line=`crusader100_read_rss ${device} ${interval} 2>/dev/null`echo "RSS LINE: $rss_line"pocet=`echo $rss_line | awk '{ print $1; }'`if [ -z "$pocet" ]; thenpocet="0"firss_avg=`echo $rss_line | awk '{ print $2; }'`rss_max=`echo $rss_line | awk '{ print $3; }'`rss_min=`echo $rss_line | awk '{ print $4; }'`if [ -z "$rss_avg" ]; thenrss_avg="0"fiif [ -z "$rss_max" ]; thenrss_max="0"fiif [ -z "$rss_min" ]; thenrss_min="0"fiif [ $pocet -gt 0 ]thenecho "Pocet vzorku: $pocet RSS avg: $rss_avg min: $rss_min max: $rss_max"rrdtool update $rrdfile.rrd -t rss_avg:rss_min:rss_max $interval:$rss_avg:$rss_min:$rss_max# rss_check_status ${name} $rss_avgelseecho "NaN"rrdtool update $rrdfile.rrd -t rss_avg:rss_min:rss_max $interval:U:U:U# rss_check_status ${name} 0fiinterval=$(( $interval + 5 ))echo ""done