Virtlab:Aktivační server
Z VirtlabWiki
Verze z 06:19, 25. 10. 2007 Gry72 (Diskuse | příspěvky) ← Předchozí porovnání |
Verze z 06:24, 25. 10. 2007 Gry72 (Diskuse | příspěvky) Následující porovnání → |
||
Řádka 8: | Řádka 8: | ||
=== Princip wrapperu pro hlídání timeoutu běhu aktivačního skriptu === | === Princip wrapperu pro hlídání timeoutu běhu aktivačního skriptu === | ||
- | Aktivační server spouští nový proces pro každou aktivaci. My v něm provedeme fork() procesu wrapperu, nastavíme alarm(), nastavíme process group (setpgrp()) na PID wrapper procesu. Z wrapper procesu provedeme fork() dalšího procesu, z něj se execl() spustí aktivační skript. Všechny procesy pod aktivačním skriptem dědí hodnotu process group. Tím je můžeme v případě vypršení časového limitu ze signal handleru pro alarm() wrapper procesu všechny společně zlikvidovat pomocí kill(cela process group), Předpokládáme, že tím skončí i proces samotného wrapperu (group leader). | + | Aktivační server spouští nový proces pro každou aktivaci. My v něm provedeme fork() procesu wrapperu, počkáme na uvolnění globálního semaforu indikujícího, že jiná instance aktivačního skriptu už neběží, nastavíme alarm(), nastavíme process group (setpgrp()) na PID wrapper procesu. Z wrapper procesu provedeme fork() dalšího procesu, z něj se execl() spustí aktivační skript. Všechny procesy pod aktivačním skriptem dědí hodnotu process group. Tím je můžeme v případě vypršení časového limitu ze signal handleru pro alarm() wrapper procesu všechny společně zlikvidovat pomocí kill(cela process group), Předpokládáme, že tím skončí i proces samotného wrapperu (group leader). |
- | '''Toto řešená není optimální, pro běžnou větší zátěž potřebujeme míž možnost plně paralelní aktivace konfigurací.''' | + | '''Toto řešená není optimální, pro běžnou větší zátěž potřebujeme míž možnost plně paralelní aktivace konfigurací.''' BUDOUCNU PROTO NUTNO PREDELAT GENERATOR A UPLOADER TAK, ABY BYLO REENTRANTNI. |
+ | Nejlépe tak, že bude generovat konfigurační soubory spojovacích prvků do zvláštních adresářů podle PID generátoru konfigurace. Z nich si je pak budou brát uploader a mazač konfigurací. Úzkým místem stále bude VLANstore, ale interakce s ním je krátká (pokud se nic nezacyklí chybou skriptu make-conn-configs). Pro realizaci kritické sekce pro komunikaci s VLANStore bashi potřebujeme mutex. Možná realizace v Bashi viz Nápověda a HOWTOs, Linuxové okénko. Skripty generátoru konfigurací by už stejně bylo vhodné přepsat do rozumnějšího jazyka, než Bash (asi C). | ||
+ | Přepsání je docela důležité, protože úplná serializace generování a uploadu konfigurací není vhodná - upload potenciálně může trvat dlouho (ikdyž se bufferuje přes konfigurační servery, takže např. povinné meziznakové prodlevy při konfiguraci Bazmeku to neovlivní). | ||
- | + | '''Vzhledem k plánovanému přechodu na jinou architekturu spojovače s pevnou konfigurací přepínačů a nahrazením ASSSK převodníky Serial-Ethernet se přechodem problém vyřeší - současný generátor konfigurací na bázi tunelovaných VLAN zanikne.''' | |
- | === V BUDOUCNU NUTNO PREDELAT GENERATOR A UPLOADER TAK, ABY BYLO REENTRANTNI === | + | |
- | + | ||
- | Nejlépe tak, že bude generovat konfigurační soubory spojovacích prvků do zvláštních adresářů podle PID generátoru konfigurace. Z nich si je pak budou brát uploader a mazač konfigurací. Úzkým místem stále bude VLANstore, ale interakce s ním je krátká (pokud se nic nezacyklí chybou skriptu make-conn-configs). Pro realizaci kritické sekce pro komunikaci s VLANStore bashi potřebujeme mutex. Možná realizace v Bashi viz Nápověda a HOWTOs, Linuxové okénko. Skripty generátoru konfigurací by už stejně bylo vhodné přepsat do rozumnějšího jazyka, než Bash (asi C). | + | |
- | + | ||
- | '''Přepsání docela důležité, protože úplná serializace generování a uploadu konfigurací není vhodná - upload potenciálně může trvat dlouho (ikdyž se bufferuje přes konfigurační servery, takže např. povinné meziznakové prodlevy při konfiguraci Bazmeku to neovlivní). | + | |
- | ''' | + | |
Verze z 06:24, 25. 10. 2007
Virtlab:Komponenty/Rozdělení rezervačního a aktivačního serveru
Princip wrapperu pro hlídání timeoutu běhu aktivačního skriptu
Aktivační server spouští nový proces pro každou aktivaci. My v něm provedeme fork() procesu wrapperu, počkáme na uvolnění globálního semaforu indikujícího, že jiná instance aktivačního skriptu už neběží, nastavíme alarm(), nastavíme process group (setpgrp()) na PID wrapper procesu. Z wrapper procesu provedeme fork() dalšího procesu, z něj se execl() spustí aktivační skript. Všechny procesy pod aktivačním skriptem dědí hodnotu process group. Tím je můžeme v případě vypršení časového limitu ze signal handleru pro alarm() wrapper procesu všechny společně zlikvidovat pomocí kill(cela process group), Předpokládáme, že tím skončí i proces samotného wrapperu (group leader).
Toto řešená není optimální, pro běžnou větší zátěž potřebujeme míž možnost plně paralelní aktivace konfigurací. BUDOUCNU PROTO NUTNO PREDELAT GENERATOR A UPLOADER TAK, ABY BYLO REENTRANTNI.
Nejlépe tak, že bude generovat konfigurační soubory spojovacích prvků do zvláštních adresářů podle PID generátoru konfigurace. Z nich si je pak budou brát uploader a mazač konfigurací. Úzkým místem stále bude VLANstore, ale interakce s ním je krátká (pokud se nic nezacyklí chybou skriptu make-conn-configs). Pro realizaci kritické sekce pro komunikaci s VLANStore bashi potřebujeme mutex. Možná realizace v Bashi viz Nápověda a HOWTOs, Linuxové okénko. Skripty generátoru konfigurací by už stejně bylo vhodné přepsat do rozumnějšího jazyka, než Bash (asi C).
Přepsání je docela důležité, protože úplná serializace generování a uploadu konfigurací není vhodná - upload potenciálně může trvat dlouho (ikdyž se bufferuje přes konfigurační servery, takže např. povinné meziznakové prodlevy při konfiguraci Bazmeku to neovlivní).
Vzhledem k plánovanému přechodu na jinou architekturu spojovače s pevnou konfigurací přepínačů a nahrazením ASSSK převodníky Serial-Ethernet se přechodem problém vyřeší - současný generátor konfigurací na bázi tunelovaných VLAN zanikne.