Bash: Performance Tricks: Unterschied zwischen den Versionen

Aus Hergipedia
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:

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.

  1. 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