Puppet (augeas)
Augeas je konfigurační nástroj, který umí zpracovat nativní formát konfiguračních souborů v systému do editovatelné stromové struktury a její modifikovaný obsah ukládat zpět tam kam patří.
Pro lokální administraci na příkazovém řádku lze použít nástroj augtool - u Debianu je v samostatném balíčku augeas-tools
. Při správě systému přes Puppet sice není zapotřebí, protože ten provádí veškeré operace prostřednictvím API, rozhodně se však hodí.
Práce s augtool
Je-li augtool spuštěn bez jakýchkoliv příkazů, spustí příkazovou řádku v interaktivní módu na které lze dále pracovat. Jako vůbec první příkaz je vhodné spustit help, který vypíše stručný přehled základních příkazů.
Pro výpis potomků na příslušné pozici se používá příkaz ls. To připomíná práci se stromovou strukturou unixových souborových systémů - nejspíš i díky tomu, že se po natažení parseru a odpovídajících konfiguračních souborů do příslušné pozice ve stromové struktuře integrují také cesty k příslušným souborům v rámci systému.
root@stroj:~# augtool -A
augtool> ls /
augeas/ = (none)
files = (none) |
Pokud spustíme augtool s parametrem -A (alt. --noautoload), který zakáže automatické natažení parsovacích filtrů i souborů |
Chceme-li vypsat celý podstrom, je třeba použít příkaz print.
augtool> print /augeas
... |
Při zadávání pozice lze s výhodou používat automatické doplňování s pomocí tabulátoru. Pěkné je, že nástroj augtool má k dispozici také vlastní historii. |
Stromová struktura augeasu
U augeasu je vše součástí jedné stromové struktury. Nejenom obsah zpracovaných textových konfiguračních souborů, ale také informace o souborech a parserech, kterými byly zpracovány.
Parsery konfiguračních souborů - lens
Pod jménem lens se u augeasu rozumí parsery konfiguračních souborů.
Jsou to skripty, u Debianu uložené v adresáři /usr/share/augeas/lenses/dist/
, s příponou .aug
, které většinou mají předdefinovány parametry pro identifikaci konfiguračních souborů, které rozparsují při svém automatickém načtení.
Toto načtení parsovacích filtrů (lenses) a parsování konfiguračních souborů, které rozpoznají, se provádí automaticky, je-li augtool spuštěn bez jakýchkoliv omezujících parametrů. Pro natažení manuální se používá příkaz load
Informace o zavedených filtrech
Informace o zavedených filtrech jsou součástí větve /augeas/load
. Viz ukázkový výpis parsovacího filtru pro zpracování konfigurace zdrojů pro APT
incl
Z názvu, který je obsahem parametru lens je zřejmé, že jde o automaticky načtený filtr, který zpracovává obsahy souborů identifikovaných jako parametry incl, tj. soubory v adresáři /etc/apt/sources.list.d
a obsah souboru /etc/apt/sources.list
.
excl
Prostřednictvím nastavení parametrů excl je naopak určeno, které soubory má parser ignorovat.
Parsovaný konfigurační soubor ve struktuře augeasu
Obsah konfiguračního souboru, zpracovaného přes parsovací filtr, je součástí větve /files
:
Jak vidět z ukázkového výpisu, je parsovaný soubor /etc/apt/sources.list
, včetně absolutní cesty, integrován do stromové struktury augeasu.
To, jak je interpretován jeho obsah závisí na použitém filtru (lens) - tomto konkrétním případě byl aplikován obsah skriptu aptsources.aug
.
Parsovaný obsah konfiguračního souboru lze vypsat také v XML formátu, a to tak, že na příslušný nod /files/etc/apt/sources.list
je aplikován místo příkazu print příkaz dump-xml
Ve stromové struktuře augeasu ale není udržován pouze obsah parsovaného souboru, ale také informace o tom, jaký parser byl na soubor aplikován a kdy došlo k poslední úpravě (mtime). To vše je součástí větve /augeas/files
Zpracování konfiguračních souborů z jiných lokací
Ve výchozím nastavení zpracovává augeas pouze konfigurační soubory umístěné v adresáři /etc
. Umožňuje ale přidat poměrně jednoduše do své stromové struktury také konfigurační soubory z jiné lokace.
- Nejdřív je třeba přidat cestu k tomuto konfiguračnímu souboru k nastavení odpovídajícího parsovacího filtru.
- A pak aplikovat příkaz load
Následující ukázkový příkaz demonstruje jak lze přidat do stromové struktury augeasu přidat ke zpracování testovací soubor se zdroji pro APT /root/sources.list.temporary
augtool> set /augeas/load/Aptsources/incl[2] /root/sources.list.temporary
|
Hodnota indexu by tedy měla být přinejhorším větší, než než je počet aktuálně nastavených parametrů incl - augtool v takovém případě použije automaticky funkci last()+1. Vhodnější je použít tuto funci rovnou:
augtool> set /augeas/load/Aptsources/incl[last()+1] /root/sources.list.temporary
|