Watchdog na routovaci tabulku: Porovnání verzí

Z HKfree wiki
Skočit na navigaci Skočit na vyhledávání
Řádek 22: Řádek 22:
 
  #
 
  #
 
   
 
   
  POLOZEK="`cat /proc/net/route | wc -l | sed s/[^0-9]//`"
+
  POLOZEK="`route -n | grep ^[0-9] | wc -l | sed s/[^0-9]//`"
 
  LIMIT=50
 
  LIMIT=50
 
   
 
   
Řádek 28: Řádek 28:
 
  then
 
  then
 
   logger "$0: Routovaci tabulka ma jen $POLOZEK radku, to je mene nez $LIMIT, restartuji procesy: zebra,  ospfd."
 
   logger "$0: Routovaci tabulka ma jen $POLOZEK radku, to je mene nez $LIMIT, restartuji procesy: zebra,  ospfd."
   sleep 5
+
   sleep 2
 
   killall ospfd
 
   killall ospfd
 
   killall zebra
 
   killall zebra

Verze z 7. 9. 2005, 12:05

Občas se na routerech stává, se zasekne proces zebra a/nebo ospfd. Normální routovací tabulka v hkfree mívá okolo 380 položek (srpen 2005). Zaseknutí zebry se projeví (kromě nefunkčnosti sítě/internetu okolo vašeho routeru) tak, že má najednou routovací tabulka pouze několik málo řádků (5-20 dle konfigurace) i přesto, že procesy běží (jsou vidět v ps) a na portech 2601 resp 2604 komunikují. Právě tohoto jevu využívá můj skript, který oba procesy zrestartuje. Je třeba ho spouštět 1x za několik minut (navrhuji 3 minuty) pomocí cronu.

Do /etc/crontab vložíme řádek:

*/3 * * * * root /usr/local/bin/routedog.sh

Vlastní skript (/usr/local/bin/routedog.sh)

#!/bin/sh
# Skript na hlidani zebry+ospfd
# VojtaLhota pro HKfree.org, 8/2005
#
# Spoustet z /etc/crontab kazdych 5 minut takto:
# "*/3 * * * * root /usr/local/bin/routedog.sh"
#
# Pokud routovaci tabulka obsahuje prilis malo zaznamu,
# svedci to o tom, ze se vnitrne zaseklo ospfd, nebo nebezi vubec.
#
# srpen 2005 - v routovacich tabulkach HKfree je cca 380 radku.
# Jako limit volim pouze 50, abych zbytecne nerestartoval kdyz se opravdu
# rozpadne sit.
#

POLOZEK="`route -n | grep ^[0-9] | wc -l | sed s/[^0-9]//`"
LIMIT=50

if [  $POLOZEK -lt $LIMIT ]
then
 logger "$0: Routovaci tabulka ma jen $POLOZEK radku, to je mene nez $LIMIT, restartuji procesy: zebra,  ospfd."
 sleep 2
 killall ospfd
 killall zebra
 sleep 1
 zebra -d
 ospfd -d
fi

zveřejnil: VojtaLhota, 19.8.2005