Linux Bash Snippet: Einträge in Logfiles zählen und summieren
Heute ein kleines Sysadmin-Helferlein aus der Kategorie “Hilfreiche Befehle für Linux, Bash und Co“. Hier möchte ich in Zukunft nützliche Kommandos, Einzeiler und Snippets für die tägliche Arbeit mit Linux als Sysadmin posten. Grund-Kenntnisse in Linux über z.B. Pipes usw. sollten vorhanden sein. Viel Spaß!
Oft ist es notwendig aus einem System-Logfile, Daten wie Befehle, Dateinamen, User-Agents, Zeiten oder was auch immer zu zählen, zu summieren und zu sortieren. Möchte man zum Beispiel wissen, welcher Befehl auf einem Webserver am meissten aufgerufen wurde, reicht ein Einzeiler:
cat access_log | awk '{print $6}' | sort | uniq -c | sort -nr | less
Was hier passiert, möchte ich kurz erklären:



