Bash: Performance Tricks: Unterschied zwischen den Versionen
Zur Navigation springen
Zur Suche springen
KKeine Bearbeitungszusammenfassung |
KKeine Bearbeitungszusammenfassung |
||
Zeile 14: | Zeile 14: | ||
Die Ursache ist meist der unnötige Aufruf externer Programme | Die Ursache ist meist der unnötige Aufruf externer Programme | ||
aus dem Skript heraus. | aus dem Skript heraus. Abhilfe schaffen einige Tricks, in der | ||
Reihenfolge einfach und effizient zu kompliziert und ineffizient. | |||
# Zusammenfassen von externen Kommandos: [[Bash-Tricks: Zusammenfassen externer Kommandos]] | |||
Als Beispiel 20 Dateien in einem Verzeichnis angezeigt werden. | Als Beispiel 20 Dateien in einem Verzeichnis angezeigt werden. | ||
Version vom 13. Januar 2010, 11:11 Uhr
Synopsis
Shell-Skripte können im Vergleich zu "echten" Programmen regelrechte Performancefallen enthalten, die nicht offensichtlich sind.
Diese können auf einfachste Weise erheblich "getunt" werden, wobei z.T. Geschwindigkeit-Steigerung um den Faktor 1000 und mehr möglich sind. Viele Dinge, die unter Linux "schnell genug" sind, werden unter Cygwin "zu langsam", was diese Plattform zu einem guten Benchmark macht.
Praxisbeispiele:
- unsere Backupsskripts,
- unser Tunnelskript
Die Ursache ist meist der unnötige Aufruf externer Programme aus dem Skript heraus. Abhilfe schaffen einige Tricks, in der Reihenfolge einfach und effizient zu kompliziert und ineffizient.
- Zusammenfassen von externen Kommandos: Bash-Tricks: Zusammenfassen externer Kommandos
Als Beispiel 20 Dateien in einem Verzeichnis angezeigt werden.
mkdir bash-performance-tricks
cd bash-performance-tricks
for ((i=0; i<20; ++i )); do echo "Hallo Welt" > $i.txt; done
einzeln innerhalb einer Schleife
# cygwin time for i in *.txt; do ls -l $i; done ... real 0m6.810s user 0m0.820s sys 0m3.880s # Linux time for i in *.txt; do ls -l $i; done ... real 0m0.060s user 0m0.004s sys 0m0.032s
in einem Rutsch
# cygwin time ls -l *.txt ... real 0m0.400s user 0m0.040s sys 0m0.230s # Linux time ls -l *.txt ... real 0m0.004s user 0m0.000s sys 0m0.000s