Bash
Bash je v informatice jeden z unixových shellů, který interpretuje příkazový řádek. Bash naprogramoval Brian Fox pro projekt GNU. Název je akronym pro Bourne again shell, což poukazuje na jeho základ v dříve nejpoužívanějším unixovém shellu Bourne shell (sh). Někdy se tento název také uvádí jako slovní hříčka odkazující na křesťanské znovuzrození (anglicky born again) nebo jako stlučení (anglicky bashing) všech výhod sh, csh a ksh. HistorieBrian Fox začal pracovat na Bashi 10. ledna 1988 poté, co začal být Richard Stallman nespokojený s pomalým postupem jeho hlavního vývojáře shellu. Stallman a celá jeho nadace Free Software Foundation (FSF) považovaly volně šiřitelný bash, který dokáže zpracovat již existující skripty pro sh, za tak klíčový a důležitý pro dokončení jejich volně šiřitelného systému postaveného na BSD a GNU kódu, že se tento projekt stal jedním z mála, které FSF financovala z vlastních zdrojů a Brian Fox se stal vedoucím tohoto projektu a zaměstnancem FSF. První betaverzi číslo .99 vydal Brian Fox 7. června 1989 a zůstal v pozici hlavního správce projektu Bash až do první poloviny roku 1994, kdy byl z FSF propuštěn a odpovědnost za projekt převzal jeho bývalý spolupracovník Chet Ramey. VlastnostiBash je POSIX shell s řadou rozšíření. Je koncipován pro operační systémy založené na projektu GNU a je možné ho spustit na většině unixových operačních systémů. Je používán jako implicitní příkazový interpret v systémech postavených na linuxovém jádře, stejně jako i v Mac OS X nebo v systému Darvin. Je možné ho použít i v systému Microsoft Windows za použití subsystému pro unixové aplikace (SUA), nebo emulace POSIX pomocí softwaru Cygwin a MSYS. Projekt DJGPP jej pak umožňuje pustit i v systému DOS. Základ syntaxe příkazů v Bashi je převzat z původního Bourne shellu. Také převážná většina sh skriptů je v Bashi spustitelná bez jakékoliv modifikace kódu až na pár výjimek, které vznikají jinou interpretací méně používané syntaxe příkazů nebo jinou implementací těchto systémových příkazů. Bash navíc převzal nápady z Korn shellu (ksh) a C shellu (csh), jako jsou například editace jednotlivých řádků, historii příkazů, proměnné Na rozdíl od Bourne shellu má Bash mnoho rozšíření i v syntaxi příkazů. Například dokáže provádět celočíselné operace bez volaní externích procesů. Za tímto účelem byla vytvořena syntaxe Bash podporuje také here dokumenty stejně jako Bourne shell. Nicméně od verze 2.05b dokáže Bash přesměrovat standardní vstup z „here-řetězce“ pomocí operátoru Bash verze 3.0 podporuje regulární výrazy se syntaxí podobnou Perlu. Bash verze 4.0 podporuje asociativní pole, která umožňují vytvářet náhradu za vícerozměrná pole: declare -A a # deklaruje asociativní pole 'a'
i=1; j=2 # inicializuje nějaké proměnné s hodnotami
a[$i,$j]=5 # asociuje hodnotu "5" s klíči "$i,$j" (neboli "1,2")
echo ${a[$i,$j]} # vypíše uložené hodnoty na klíči "$i,$j"
Expanze závorekExpanze závorek (anglicky brace expansion, též záměna) je vlastnost zkopírovaná z C shellu, která generuje množinu možných kombinací. Výsledky nemusí být v pořadí, jak je uvedeno v příkladu: echo a{p,c,d,b}e # ape ace ade abe
echo {a,b,c}{d,e,f} # ad ae af bd be bf cd ce cf
Toto rozšíření by nemělo být použito v přenositelných skriptech, protože Bourne shell nevytvoří stejný výstup. # Klasický shell nevytvoří stejný výstup, expanzi nepodporuje
echo a{p,c,d,b}e # a{p,c,d,b}e
Pokud je expanze použita v kombinaci se zástupnými znaky, nejdříve se provede expanze a poté se teprve nahradí zástupné znaky. Výpis souborů s obrázky typu JPEG a PNG pak může vypadat následovně: ls *.{jpg,jpeg,png} # rozšíří na *.jpg *.jpeg *.png - a poté,
# se vyhledají soubory odpovídající zástupným znakům
Startovací skriptyKdyž Bash startuje, vykoná příkazy v několika různých skriptech. Pokud je spuštěn za účelem přihlášení uživatele (login shell), nejdříve vykoná příkazy ze souboru Pokud je uživatel ze shellu odhlášen, vyhledá se a provede se skript ze souboru Pokud je Bash spuštěn bez přihlášení uživatele, vykonají se skripty ze souboru Některé verze Unixu obsahují speciálně upravené systémové skripty pro Bash, které schválně změní pořadí zmiňovaných skriptů tím, že spustí některé skripty dříve nebo nakombinují spouštění Bashe se startovacími skripty z jiných shellů různými způsoby. PřenositelnostShellové skripty napsané podle specifikací Bashe (bashisms) nebudou spolehlivě fungovat na systému, který využívá Bourne shell nebo nějakou z jeho náhražek, pokud nebude na takovém systému nainstalován také Bash a daný skript nebude na začátku obsahovat speciální příkaz (shebang) obsahující Klávesové zkratkyBash pro editování příkazového řádku využívá knihovnu GNU Readline, která nabízí pro editaci představenou sadu klávesových zkratek inspirovaných textovým editor Emacs. Příkazem K tomu má Bash navíc své vlastní klávesové zkratky, například Ctrl-c odesílá signál SIGINT právě probíhající úloze, který způsobí její přerušení a zavření, Ctrl-d odešle příznak EOF (End Of File), který (pokud není tato funkce vypnuta v nastavení) zavře právě aktivní shell (stejně jako příkaz Sám Bash obvykle běží jako součást terminálového programu, který může některé klávesové zkratky odchytávat a zpracovávat a Bashi je nepředat. Bezpečnostní chyba „Shellshock“V září 2014 byla v Bashi objevena závažná zranitelnost (v registru CVE označená identifikátorem CVE-2014-6271[1]) později označovaná jako Shellshock.[2] Kvůli této chybě Bash nesprávně provádí libovolný kód, pokud je zvláštním způsobem zapsán v proměnných prostředí. Jelikož se Bash používá pro provádění skriptů ve velkém množství internetových služeb, jako jsou například webové servery, a některým skriptům (např. CGI skriptům) se uživatelský vstup předává právě ve formě proměnných prostředí, znamená tato chyba, že kdokoli, kdo je schopen na zranitelný stroj poslat nějaký požadavek, může na tomto stroji provádět libovolné příkazy. Tato chyba navíc v Bashi existovala zhruba od roku 1992.[2] Po urychleném vydání bezpečnostních aktualizací následovalo odhalení dalších souvisejících zranitelností v syntaktickém analyzátoru v Bashi a jejich postupné záplatování. Reference
Externí odkazy
|