„Bash (Shell)“ – Versionsunterschied
[gesichtete Version] | [gesichtete Version] |
K Programmiersprache in Infobox(Software) |
K linkfix |
||
Zeile 167: | Zeile 167: | ||
== Weblinks == |
== Weblinks == |
||
{{Wikibooks|Linux- |
{{Wikibooks|Linux-Praxisbuch: Shellprogrammierung}} |
||
* {{man|1|bash}} |
* {{man|1|bash}} |
||
* [http://tiswww.case.edu/php/chet/bash/bashtop.html Homepage] |
* [http://tiswww.case.edu/php/chet/bash/bashtop.html Homepage] |
Version vom 27. Dezember 2013, 20:29 Uhr
Bash
| |
---|---|
![]() | |
![]() Beispiel einer bash-Sitzung | |
Basisdaten
| |
Maintainer | Chet Ramey |
Entwickler | Chet Ramey |
Erscheinungsjahr | 8. Juni 1989 |
Aktuelle Version | 4.2 (13. Februar 2011) |
Betriebssystem | Unix, u. a. Linux |
Programmiersprache | C |
Kategorie | Kommandozeileninterpreter |
Lizenz | GPL (Freie Software) |
deutschsprachig | ja |
tiswww.case.edu |
Die Bourne-again shell (bash) ist eine freie Unix-Shell und Teil des GNU-Projekts. Sie ist heute auf vielen unixoiden Systemen die Standard-Shell.
Der Name ist absichtlich mehrdeutig und bedeutet unter anderem „wiedergeborene (born again) Shell“, „wieder einmal (eine) Bourne-Shell“ oder auch aus dem Englischen to bash (schlagen, kritisieren, schlecht machen) bzw. umgangssprachlich „Party/Fete“.
Geschichte
Geschrieben wurde bash 1987 von Brian Fox und wurde 1990 von Chet Ramey übernommen. Version 3 erschien am 27. Juli 2004. Version 4 erschien am 20. Februar 2009 und brachte einige Neuerungen mit sich. Darunter sind eine neue Ausgabeumleitung, assoziative Arrays und eine neue Wildcard (**).[1][2]
Funktionalität
Die Shell ist weitgehend kompatibel zur Bourne-Shell (sh) und beherrscht zusätzlich sowohl die meisten Funktionen der Korn Shell (ksh) als auch Teile der C-Shell (csh)-Syntax, wie zum Beispiel die „Command-History“, die $RANDOM-Variable und die POSIX-Form der Command-Substitution $(...) wurden übernommen. Auch wurde sie um Funktionen wie z. B. der Ganzzahlarithmetik ohne die Ausführung externer Prozesse und Vereinfachung der I/O-Umleitungen erweitert. Bash bietet außerdem die Möglichkeit, in der Datei ~/.bashrc eigene Einstellungen wie Designs zu speichern.
Shell und Subshell
Die bash kann auf zwei Arten aktiviert werden. Sie kann mit dem Login gestartet werden, eine solche Shell nennt man daher Login-Shell. Die bash kann aber auch als Subshell (der Login-Shell) gestartet werden, etwa durch einen neuerlichen Aufruf der bash. Auch Shells in grafischen Oberflächen wie kterm oder gnome-terminal gelten als Subshell, da mit ihnen kein Login verbunden ist. Ebenso werden Programme in einer Subshell ausgeführt.
Konfiguration
Die bash verfügt daher auch über zwei Arten der Konfiguration. Die Login-Shell wird systemweit mit /etc/profile und danach userspezifisch mit ~/.bash_profile (oder anderen Dateien) konfiguriert. Bei der Abmeldung wird ~/.bash_logout ausgeführt. Eine Subshell wird systemweit über /etc/bashrc und danach über ~/.bashrc konfiguriert. Im Verzeichnis /etc/skel existieren Vorlagen dieser Dateien, die neuen Benutzern ins Heimatverzeichnis kopiert werden.
Eingebaute Befehle
Die bash enthält zahlreiche, eingebaute Befehle und reservierte Wörter. Zu den eingebauten Befehlen zählen beispielsweise alias, cd, exit, help, kill, logout oder pwd und zu den reservierten Wörtern zählen die für die bash-Programmierung nötigen Schlüsselwörter wie case, for, function oder while.
Platzhalter
Als Platzhalter verwendet die bash den * für beliebig viele Zeichen und das ? für genau ein Zeichen. Mit [ und ] lassen sich auch Zeichenmengen angeben und mit { und } sogenannte Klammererweiterungen.
Ein- und Ausgabe, Umleitung
In der bash existieren drei sogenannte Standarddateien, die aber keine echten Dateien, sondern Dateideskriptoren sind, die von der bash wie Dateien behandelt werden. Es sind dies die Standardeingabe stdin, die Standardausgabe stdout und der Standardfehler stderr. Ein in der bash ausgeführtes Programm liest von der Standardeingabe, normalerweise ist das die Tastatur, und gibt das Ergebnis an die Standardausgabe weiter, normalerweise ist das der Bildschirm. Auch Fehlermeldungen werden via Standardfehler am Bildschirm ausgegeben. Im nachfolgenden Beispiel wird das Konzept der Standardeingabe und -ausgabe sichtbar:
user$ echo "Dieser lan\
> ge Satz ers\
> treckt sich übe\
> r eine Zeile."
Dieser lange Satz erstreckt sich über eine Zeile.
Diese drei Standarddateien können über ihren Kanal angesprochen werden, wobei 0 für die Standardeingabe, 1 für die die Standardausgabe und 2 für den Standardfehler steht.
Die Standarddateien können auch umgeleitet werden, wofür die Zeichen >, < und | zur Verfügung stehen. Nachfolgend wird die Standardausgabe von ls *.txt in die Datei verzeichnis.info umgeleitet und danach von less als Standardeingabe eingelesen:
user$ ls *.txt > verzeichnis.info
user$ less < verzeichnis.info
Mit der Pipe lassen sich Ein- und Ausgaben auch direkt umleiten.
set-Optionen
Die bash verfügt über 27 Optionen, mit denen ein anderer Betriebsmodus eingestellt werden kann. Alle möglichen Einstellungen können mit
user$ set -o
aufgelistet werden, wobei mit der Option -o die Modi gelistet werden bzw. gesetzt werden und mit der Option +o die Option wieder aufgehoben wird. Das + ist dabei als durchgestrichenes - zu lesen. Gebräuchlich sind die Optionen noclobber, mit der der Ausgabeumleitung untersagt wird, vorhandene Dateien zu überschreiben, die Option noglob, bei der für Dateinamen keine Platzhalter wie * und ? möglich sind und die Option xtrace, bei der jedes Shell-Kommando vor der Ausführung nochmals ausgegeben wird, und zwar mit den intern vorgenommenen Erweiterungen, was bei der Fehlersuche nützlich sein kann.
Das Überschreiben der Ausgabeumleitung wird unterdrückt:
user$ echo "hallo" > hallo.txt
user$ echo "hallo" > hallo.txt
user$ set -o noclobber
user$ echo "hallo" > hallo.txt
-su: hallo.txt: Kann existierende Datei nicht überschreiben.
user$ set +o noclobber
user$ echo "hallo" > hallo.txt
Man kann Dateinamen mit Stern und Fragezeichen erzeugen. Vor der Abfrage mit ls *sh muss die Option wieder zurück gesetzt werden, denn sonst würde nach der Datei *sh gesucht werden.
user$ set -o noglob
user$ touch da*tei.sh
user$ touch dat?ei.sh
user$ set +o noglob
user$ ls *sh
da*tei.sh dat?ei.sh
Die dritte Zeile zeigt die von der bash vorgenommenen Erweiterungen an:
user$ set -o xtrace
user$ ls *.txt
+ ls --color=auto hallo.txt test.txt text.txt
hallo.txt test.txt text.txt
Alle Optionen können auch mittels einer Kurz-Schreibweise gesetzt werden, beispielsweise ist set -C gleichbedeutend mit set -o noclobber.
Umgebungsvariablen
In der bash können Variablen auf mehrere Arten definiert werden. Grundsätzlich unterscheidet man zwischen lokalen Variablen, die nur in der Shell gelten, in der sie definiert wurden, und globalen Variablen, die auch in Sub-Prozessen zugewiesen sind. Lokale Variablen können erzeugt werden mit:
user$ var=var1
user$ var='var zwei'
user$ let var=var3
user$ declare var=var4
und globale Variablen werden definiert mit:
user$ declare -x var=var5
user$ export var=var6
Angesprochen werden die Variablen mit dem $-Zeichen:
user$ echo $var
Eingebaute Umgebungsvariablen
Die bash verfügt über zahlreiche eingebaute Umgebungsvariablen, die auch häufig von anderen Kommandos ausgewertet werden. Bekannt sind die Variablen PATH für den Suchpfad, LANG für die Einstellung der Sprache oder PS1 für den Prompt.
Beispielsweise können die englischsprachigen Hilfeseiten vom ls mit dem nachfolgenden Befehl aufgerufen werden. Hier wird eine Sub-Shell erzeugt, darin die LANG-Umgebungsvariable überschrieben und anschließend der Befehl man ls ausgeführt.
user$ LANG=en man ls
Programmierung
Bash-Programmierung unterscheidet sich in vielen Punkten von anderen Programmiersprachen. So wird beispielsweise bei der Verzweigung traditionell die Bedingung nicht von der Shell selbst ausgewertet, sondern an ein weiteres Programm übergeben:
if [ Bedingung ] ; then
# Falls Bedingung wahr ist, wird dies ausgeführt
else
# Falls Bedingung falsch ist, wird dies ausgeführt
fi
Die beiden eckigen Klammern sind keine Begrenzer, sondern ein Synonym für den integrierten (builtin) Shell-Befehl test
. Der Befehl test
prüft die Bedingung und liefert einen Rückgabewert 0 (wahr) oder 1 (falsch), der von der if
-Anweisung verarbeitet wird. Der oben angeführte Code ist also identisch mit der folgenden Schreibweise:
if test Bedingung ; then
# Falls Bedingung wahr ist, wird dies ausgeführt
else
# Falls Bedingung falsch ist, wird dies ausgeführt
fi
Heutzutage existiert jedoch auch ein eingebauter Ausdruck, der ohne externen Befehl auskommt, daher nicht mehr den Beschränkungen unterliegt, denen die Befehlsform unterlag, und so unter anderem auch keine Anführungszeichen um Variablen mehr benötigt:
if [[ Bedingung ]] ; then
# Falls Bedingung wahr ist, wird dies ausgeführt
else
# Falls Bedingung falsch ist, wird dies ausgeführt
fi
Hier kann die Bedingung nun z. B. auch Operatoren wie <
, >
(kleiner als und größer als), und =~
(Vergleich mit Regulärem Ausdruck) enthalten.
Diese Variante wird daher, wenn keine Kompatibilität zu älteren Versionen benötigt wird, generell empfohlen.
Jedoch kann auch weiterhin der Rückgabewert (0–127, wobei >0 = falsch) eines beliebigen Programmes verarbeitet werden. Nicht nur der des test
-Befehls. Als Beispiel wird hier der kill
-Befehl verwendet, um zu testen, ob ein Prozess mit einer bestimmten Nummer noch läuft bzw. in der Lage ist, Signale entgegenzunehmen:
if kill -0 1234 ; then
# Prozess 1234 läuft
else
# Prozess 1234 läuft nicht
fi
Literatur
- Christian Meißner: Bash – Arbeiten und programmieren mit der Shell. Open Source Press, August 2011, ISBN 978-3-941841-44-4.
- Karsten Günther: Bash - kurz & gut. 2008, ISBN 978-3-89721-533-7.
- Cameron Newham, Bill Rosenblatt: Learning the Bash Shell, 2nd Edition. O’Reilly & Associates, Inc., 1998, ISBN 1-56592-347-2.
Weblinks
bash(1)
– Debian GNU/Linux Ausführbare Programme oder Shell-Befehle Handbuchseite- Homepage
- Bash auf der GNU-Seite
- SelfLinux: Shellprogrammierung
- Advanced Bash-Scripting Guide ePub-Version (englisch)