Hash: Unterschied zwischen den Versionen
K Textersetzung - „Kategorie:Entwurf“ durch „“ |
K Textersetzung - „== Syntax ==“ durch „== Aufruf ==“ |
||
(10 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) | |||
Zeile 17: | Zeile 17: | ||
== Installation == | == Installation == | ||
''hash'' ist ein [[:Kategorie:Bash | ''hash'' ist ein [[:Kategorie:Bash/Builtin|interner Befehl]] der [[Bash]] und muss nicht separat installiert werden | ||
== Anwendungen == | == Anwendungen == | ||
Zeile 56: | Zeile 56: | ||
$ '''hash -p <Pfad_zum_Kommando>''' | $ '''hash -p <Pfad_zum_Kommando>''' | ||
== | == Aufruf == | ||
$ '''hash [-lr] [-p Pfadname] [-dt] [Name ...]''' | $ '''hash [-lr] [-p Pfadname] [-dt] [Name ...]''' | ||
Zeile 83: | Zeile 83: | ||
|} | |} | ||
=== | === Umgebung === | ||
=== | === Rückgabewert === | ||
Gibt Erfolg zurück, es sei denn, NAME wird nicht gefunden oder es wird eine ungültige Option angegeben. | Gibt Erfolg zurück, es sei denn, NAME wird nicht gefunden oder es wird eine ungültige Option angegeben. | ||
Zeile 92: | Zeile 92: | ||
== Dokumentation == | == Dokumentation == | ||
=== RFC === | === RFC === | ||
=== Man- | === Man-Page === | ||
=== Info-Pages === | === Info-Pages === | ||
== Siehe auch == | == Siehe auch == | ||
Zeile 98: | Zeile 98: | ||
=== Projekt === | === Projekt === | ||
=== Weblinks === | === Weblinks === | ||
[[Kategorie:Bash | |||
[[Kategorie:Bash | [[Kategorie:Bash/Builtin]] | ||
[[Kategorie:Linux | [[Kategorie:Bash/Interaktiv]] | ||
[[Kategorie:Linux/Befehl]] | |||
{{DEFAULTSORT:hash}} | {{DEFAULTSORT:hash}} |
Aktuelle Version vom 12. November 2024, 18:44 Uhr
hash - Verwaltung der Hash-Tabelle für Kommando-Pfade
Beschreibung
- Programmpfade merken oder anzeigen
- Ermittelt und speichert den vollständigen Pfadnamen jedes Kommandos NAME
- Wenn keine Argumente angegeben werden, werden Informationen über gespeicherte Kommandos angezeigt
- Ein angegebenes Kommando muss von der Shell gesucht werden
- Die Suche, vor allem wenn sie die Angaben aus PATH einschließt, kostet Zeit.
- Deswegen merkt sich die Bash die Zugriffspfade zu allen externen Kommandos in einer Hashtabelle.
- Hashtabelle wird zuerst konsultiert
- Nur wenn der Pfad zu einem Kommando dort nicht erfasst wird, werden die Verzeichnispfade durchsucht
- Es sei denn hashall ist nicht gesetzt (siehe set)
- Beim nächsten Zugriff auf das Kommando wird haman den Geschwindigkeitszuwachs spüren.
Installation
hash ist ein interner Befehl der Bash und muss nicht separat installiert werden
Anwendungen
Pfad-Cache
$ hash
- (ohne Parameter) zeigt die Liste der gemerkten Pfade zu den Programmen an.
- Um die Zugriffe auf Programme zu beschleunigen, verwaltet die Bash einen internen Cache der Pfade auf bereits gestartete Programme.
- Wird ein Programm erneut gestartet, kann die zeitaufwendige Suche entlang des Pfades entfallen.
- Bei der Gelegenheit wird auch gleich angezeigt, wie oft das Programm gestartet wurde.
Verwerfen alle Pfade
$ hash -r
Anzeige der Hashtabelle
$ hash hits command 2 /bin/ls 1 /bin/mv 6 /bin/sh 8 /usr/bin/vi 1 /bin/chmod 3 /bin/date 1 /usr/bin/id 1 /usr/bin/man
Gleichnamigen Kommandos
- Liegt eines in der Hashtabelle vor, so kann auf das andere nur über die vollständige Pfadangabe zugegriffen werden
- Soll dieses "benachteiligte" Kommando nun vermehrt eingesetzt werden, ist ein Löschen der Hashtabelle mittels »-r« sinnvoll
$ hash -r $ hash hash: hash table empty
Indem »hash« mit einem oder mehreren Kommandonamen aufgerufen wird, werden diese Kommandos gesucht und in die Hashtabelle aufgenommen; sie werden jedoch nicht gestartet (sinnvoll ist dies eventuell in Startskripten).
Pfad zur Tabelle hinzufügen
$ hash -p <Pfad_zum_Kommando>
Aufruf
$ hash [-lr] [-p Pfadname] [-dt] [Name ...]
Optionen
Option | Beschreibung |
---|---|
-d | Vergessen des Speicherortes für jeden NAME |
-l | Anzeige in einem Format, das als Eingabe wiederverwendet werden kann |
-p | Pfadname verwendet PATHNAME als den vollständigen Pfadnamen von NAME |
-r | vergisst alle gespeicherten Pfade |
-t | gibt den Speicherort jedes NAMENS aus, wobei jedem Speicherort der entsprechende NAME vorangestellt wird, wenn mehrere NAMEs angegeben sind |
Parameter
Option | Beschreibung |
---|---|
NAME | Jeder NAME wird in PATH gesucht und in die Liste der gespeicherten Befehle hinzugefügt |
Umgebung
Rückgabewert
Gibt Erfolg zurück, es sei denn, NAME wird nicht gefunden oder es wird eine ungültige Option angegeben.