Linux Forensics
Verwenden Sie Trickest, um einfach Workflows zu erstellen und zu automatisieren, die von den weltweit fortschrittlichsten Community-Tools unterstützt werden. Heute Zugriff erhalten:
Initiale Informationsbeschaffung
Grundlegende Informationen
Zunächst wird empfohlen, einen USB-Stick mit bekannten guten Binärdateien und Bibliotheken darauf zu haben (Sie können einfach Ubuntu nehmen und die Ordner /bin, /sbin, /lib und /lib64 kopieren), dann den USB-Stick einbinden und die Umgebungsvariablen ändern, um diese Binärdateien zu verwenden:
Sobald Sie das System so konfiguriert haben, dass gute und bekannte Binärdateien verwendet werden, können Sie damit beginnen, grundlegende Informationen zu extrahieren:
Verdächtige Informationen
Beim Abrufen der grundlegenden Informationen sollten Sie nach seltsamen Dingen wie:
Root-Prozesse laufen normalerweise mit niedrigen PIDs, daher sollten Sie misstrauisch sein, wenn Sie einen Root-Prozess mit einer hohen PID finden
Überprüfen Sie die registrierten Anmeldungen von Benutzern ohne Shell in
/etc/passwd
Überprüfen Sie Passwort-Hashes in
/etc/shadow
für Benutzer ohne Shell
Speicherabbild
Um den Speicher des laufenden Systems zu erhalten, wird empfohlen, LiME zu verwenden. Um es zu kompilieren, müssen Sie den gleichen Kernel verwenden, den die Opfermaschine verwendet.
Denken Sie daran, dass Sie LiME oder irgendetwas anderes nicht auf der Opfermaschine installieren können, da dies mehrere Änderungen daran vornehmen würde
Wenn Sie also eine identische Version von Ubuntu haben, können Sie apt-get install lime-forensics-dkms
verwenden.
In anderen Fällen müssen Sie LiME von Github herunterladen und es mit den richtigen Kernel-Headern kompilieren. Um die genauen Kernel-Header der Opfermaschine zu erhalten, können Sie einfach das Verzeichnis /lib/modules/<Kernel-Version>
auf Ihren Computer kopieren und dann LiME damit kompilieren:
LiME unterstützt 3 Formate:
Roh (jedes Segment zusammengefügt)
Gepolstert (wie Roh, aber mit Nullen in den rechten Bits)
Lime (empfohlenes Format mit Metadaten)
LiME kann auch verwendet werden, um das Dump über das Netzwerk zu senden, anstatt es im System zu speichern, indem man etwas wie: path=tcp:4444
verwendet.
Festplattenabbildung
Herunterfahren
Zunächst müssen Sie das System herunterfahren. Dies ist nicht immer eine Option, da das System manchmal ein Produktionsserver ist, den sich das Unternehmen nicht leisten kann herunterzufahren.
Es gibt 2 Möglichkeiten, das System herunterzufahren, ein normales Herunterfahren und ein "Stecker ziehen" Herunterfahren. Das erste ermöglicht es den Prozessen, wie gewohnt zu beenden und das Dateisystem zu synchronisieren, erlaubt aber auch möglicherweise der Malware, Beweise zu vernichten. Der Ansatz "Stecker ziehen" kann zu einigem Informationsverlust führen (nicht viele Informationen gehen verloren, da wir bereits ein Abbild des Speichers gemacht haben) und die Malware wird keine Gelegenheit haben, etwas dagegen zu unternehmen. Wenn Sie also vermuten, dass es Malware geben könnte, führen Sie einfach den sync
Befehl auf dem System aus und ziehen Sie den Stecker.
Erstellen eines Abbilds der Festplatte
Es ist wichtig zu beachten, dass bevor Sie Ihren Computer mit etwas in Verbindung bringen, das mit dem Fall zusammenhängt, Sie sicherstellen müssen, dass es als schreibgeschützt eingebunden wird, um eine Änderung von Informationen zu vermeiden.
Voranalyse des Festplattenimages
Erstellen eines Festplattenimages ohne weitere Daten.
Verwenden Sie Trickest, um einfach Workflows zu erstellen und zu automatisieren, die von den fortschrittlichsten Community-Tools der Welt unterstützt werden. Heute Zugriff erhalten:
Suche nach bekannten Malware
Modifizierte Systemdateien
Linux bietet Tools zur Sicherung der Integrität von Systemkomponenten, die entscheidend sind, um potenziell problematische Dateien zu erkennen.
RedHat-basierte Systeme: Verwenden Sie
rpm -Va
für eine umfassende Überprüfung.Debian-basierte Systeme:
dpkg --verify
für die erste Überprüfung, gefolgt vondebsums | grep -v "OK$"
(nach der Installation vondebsums
mitapt-get install debsums
), um etwaige Probleme zu identifizieren.
Malware/Rootkit-Detektoren
Lesen Sie die folgende Seite, um mehr über Tools zu erfahren, die nützlich sein können, um Malware zu finden:
pageMalware AnalysisSuche nach installierten Programmen
Um effektiv nach installierten Programmen auf Debian- und RedHat-Systemen zu suchen, sollten Sie Systemprotokolle und Datenbanken in Kombination mit manuellen Überprüfungen in gängigen Verzeichnissen nutzen.
Für Debian überprüfen Sie
/var/lib/dpkg/status
und **/var/log/dpkg.log
, um Details zu Paketinstallationen abzurufen, und verwenden Siegrep
, um nach spezifischen Informationen zu filtern.RedHat-Benutzer können die RPM-Datenbank mit
rpm -qa --root=/mntpath/var/lib/rpm
abfragen, um installierte Pakete aufzulisten.
Um Software zu entdecken, die manuell oder außerhalb dieser Paketmanager installiert wurde, erkunden Sie Verzeichnisse wie /usr/local
, /opt
, /usr/sbin
, /usr/bin
, /bin
und /sbin
. Kombinieren Sie Verzeichnisauflistungen mit systemspezifischen Befehlen, um ausführbare Dateien zu identifizieren, die nicht mit bekannten Paketen verbunden sind, und verbessern Sie so Ihre Suche nach allen installierten Programmen.
Verwenden Sie Trickest, um einfach Workflows zu erstellen und zu automatisieren, die von den fortschrittlichsten Community-Tools der Welt unterstützt werden. Heute Zugriff erhalten:
Wiederherstellen gelöschter ausführbarer Dateien
Stellen Sie sich einen Prozess vor, der von /tmp/exec ausgeführt und dann gelöscht wurde. Es ist möglich, ihn wiederherzustellen.
Überprüfen von Autostart-Orten
Geplante Aufgaben
Dienste
Pfade, an denen sich Malware als Dienst installieren könnte:
/etc/inittab: Ruft Initialisierungsskripte wie rc.sysinit auf, die dann zu Startskripten weiterleiten.
/etc/rc.d/ und /etc/rc.boot/: Enthalten Skripte für den Dienststart, wobei letzteres in älteren Linux-Versionen zu finden ist.
/etc/init.d/: Wird in bestimmten Linux-Versionen wie Debian zum Speichern von Startskripten verwendet.
Dienste können auch über /etc/inetd.conf oder /etc/xinetd/ aktiviert werden, abhängig von der Linux-Variante.
/etc/systemd/system: Ein Verzeichnis für System- und Dienstverwaltungsskripte.
/etc/systemd/system/multi-user.target.wants/: Enthält Links zu Diensten, die in einem Multi-User-Runlevel gestartet werden sollen.
/usr/local/etc/rc.d/: Für benutzerdefinierte oder Drittanbieterdienste.
~/.config/autostart/: Für benutzerspezifische automatische Startanwendungen, die ein Versteck für auf Benutzer abzielende Malware sein können.
/lib/systemd/system/: Systemweite Standard-Unit-Dateien, die von installierten Paketen bereitgestellt werden.
Kernelmodule
Linux-Kernelmodule, die von Malware oft als Rootkit-Komponenten genutzt werden, werden beim Systemstart geladen. Die Verzeichnisse und Dateien, die für diese Module entscheidend sind, umfassen:
/lib/modules/$(uname -r): Enthält Module für die aktuelle Kernelversion.
/etc/modprobe.d: Enthält Konfigurationsdateien zur Steuerung des Modulladens.
/etc/modprobe und /etc/modprobe.conf: Dateien für globale Moduleinstellungen.
Andere Autostartpositionen
Linux verwendet verschiedene Dateien, um Programme automatisch beim Benutzerlogin auszuführen, die potenziell Malware beherbergen können:
/etc/profile.d/*, /etc/profile und /etc/bash.bashrc: Wird bei jedem Benutzerlogin ausgeführt.
~/.bashrc, ~/.bash_profile, ~/.profile und ~/.config/autostart: Benutzerspezifische Dateien, die bei deren Anmeldung ausgeführt werden.
/etc/rc.local: Wird nach dem Start aller Systemdienste ausgeführt und markiert das Ende des Übergangs in eine Multiuser-Umgebung.
Protokolle überprüfen
Linux-Systeme verfolgen Benutzeraktivitäten und Systemereignisse in verschiedenen Protokolldateien. Diese Protokolle sind entscheidend, um unbefugten Zugriff, Malware-Infektionen und andere Sicherheitsvorfälle zu identifizieren. Wichtige Protokolldateien sind:
/var/log/syslog (Debian) oder /var/log/messages (RedHat): Erfassen systemweite Nachrichten und Aktivitäten.
/var/log/auth.log (Debian) oder /var/log/secure (RedHat): Protokollieren Authentifizierungsversuche, erfolgreiche und fehlgeschlagene Anmeldungen.
Verwenden Sie
grep -iE "session opened for|accepted password|new session|not in sudoers" /var/log/auth.log
, um relevante Authentifizierungsereignisse zu filtern./var/log/boot.log: Enthält Systemstartnachrichten.
/var/log/maillog oder /var/log/mail.log: Protokollieren E-Mail-Serveraktivitäten, nützlich zur Verfolgung von E-Mail-Diensten.
/var/log/kern.log: Speichert Kernelnachrichten, einschließlich Fehler und Warnungen.
/var/log/dmesg: Enthält Gerätetreiber-Nachrichten.
/var/log/faillog: Protokolliert fehlgeschlagene Anmeldeversuche und unterstützt bei Sicherheitsverletzungsuntersuchungen.
/var/log/cron: Protokolliert Cron-Jobausführungen.
/var/log/daemon.log: Verfolgt Hintergrunddienstaktivitäten.
/var/log/btmp: Dokumentiert fehlgeschlagene Anmeldeversuche.
/var/log/httpd/: Enthält Apache HTTPD Fehler- und Zugriffsprotokolle.
/var/log/mysqld.log oder /var/log/mysql.log: Protokollieren MySQL-Datenbankaktivitäten.
/var/log/xferlog: Protokolliert FTP-Dateiübertragungen.
/var/log/: Überprüfen Sie hier immer auf unerwartete Protokolle.
Linux-Systemprotokolle und Überwachungssysteme können in einem Eindringungs- oder Malware-Vorfall deaktiviert oder gelöscht werden. Da Protokolle auf Linux-Systemen im Allgemeinen einige der nützlichsten Informationen über bösartige Aktivitäten enthalten, löschen Eindringlinge sie routinemäßig. Daher ist es beim Untersuchen verfügbarer Protokolldateien wichtig, nach Lücken oder falsch sortierten Einträgen zu suchen, die auf Löschungen oder Manipulationen hinweisen könnten.
Linux speichert eine Befehlshistorie für jeden Benutzer, gespeichert in:
~/.bash_history
~/.zsh_history
~/.zsh_sessions/*
~/.python_history
~/.*_history
Darüber hinaus liefert der Befehl last -Faiwx
eine Liste der Benutzeranmeldungen. Überprüfen Sie diese auf unbekannte oder unerwartete Anmeldungen.
Überprüfen Sie Dateien, die zusätzliche Berechtigungen gewähren können:
Überprüfen Sie
/etc/sudoers
auf unerwartete Benutzerberechtigungen, die möglicherweise gewährt wurden.Überprüfen Sie
/etc/sudoers.d/
auf unerwartete Benutzerberechtigungen, die möglicherweise gewährt wurden.Untersuchen Sie
/etc/groups
, um ungewöhnliche Gruppenmitgliedschaften oder Berechtigungen zu identifizieren.Untersuchen Sie
/etc/passwd
, um ungewöhnliche Gruppenmitgliedschaften oder Berechtigungen zu identifizieren.
Einige Apps generieren auch ihre eigenen Protokolle:
SSH: Überprüfen Sie ~/.ssh/authorized_keys und ~/.ssh/known_hosts auf nicht autorisierte Remoteverbindungen.
Gnome-Desktop: Sehen Sie sich ~/.recently-used.xbel für kürzlich über Gnome-Anwendungen zugegriffene Dateien an.
Firefox/Chrome: Überprüfen Sie den Browserverlauf und Downloads in ~/.mozilla/firefox oder ~/.config/google-chrome auf verdächtige Aktivitäten.
VIM: Überprüfen Sie ~/.viminfo auf Details zur Verwendung, wie z. B. aufgerufene Dateipfade und Suchverlauf.
Open Office: Überprüfen Sie kürzlich aufgerufene Dokumente, die auf kompromittierte Dateien hinweisen könnten.
FTP/SFTP: Überprüfen Sie Protokolle in ~/.ftp_history oder ~/.sftp_history auf Dateiübertragungen, die möglicherweise nicht autorisiert sind.
MySQL: Untersuchen Sie ~/.mysql_history auf ausgeführte MySQL-Abfragen, die möglicherweise nicht autorisierte Datenbankaktivitäten aufdecken.
Less: Analysieren Sie ~/.lesshst für die Verlaufsnutzung, einschließlich angezeigter Dateien und ausgeführter Befehle.
Git: Überprüfen Sie ~/.gitconfig und Projekt .git/logs auf Änderungen an Repositories.
USB-Protokolle
usbrip ist eine kleine Software, die in reinem Python 3 geschrieben ist und Linux-Protokolldateien (/var/log/syslog*
oder /var/log/messages*
je nach Distribution) analysiert, um USB-Ereignisverlaufstabellen zu erstellen.
Es ist interessant zu wissen, welche USBs verwendet wurden, und es ist nützlicher, wenn Sie eine autorisierte Liste von USBs haben, um "Verstoßereignisse" zu finden (die Verwendung von USBs, die nicht in dieser Liste enthalten sind).
Installation
Beispiele
Mehr Beispiele und Informationen finden Sie auf Github: https://github.com/snovvcrash/usbrip
Verwenden Sie Trickest, um einfach Workflows zu erstellen und zu automatisieren, die von den fortschrittlichsten Community-Tools der Welt unterstützt werden. Heute Zugriff erhalten:
Überprüfung von Benutzerkonten und Anmeldeaktivitäten
Untersuchen Sie die Dateien /etc/passwd, /etc/shadow und Sicherheitsprotokolle auf ungewöhnliche Namen oder Konten, die erstellt oder in unmittelbarer Nähe zu bekannten unbefugten Ereignissen verwendet wurden. Überprüfen Sie auch mögliche sudo-Brute-Force-Angriffe. Überprüfen Sie außerdem Dateien wie /etc/sudoers und /etc/groups auf unerwartete Berechtigungen, die Benutzern erteilt wurden. Suchen Sie schließlich nach Konten ohne Passwörter oder mit leicht erratbaren Passwörtern.
Dateisystem untersuchen
Analyse von Dateisystemstrukturen bei der Malware-Untersuchung
Bei der Untersuchung von Malware-Vorfällen ist die Struktur des Dateisystems eine entscheidende Informationsquelle, die sowohl die Ereignisabfolge als auch den Inhalt der Malware aufzeigt. Malware-Autoren entwickeln jedoch Techniken, um diese Analyse zu erschweren, z. B. durch Ändern von Dateizeitstempeln oder Vermeiden des Dateisystems zur Datenspeicherung.
Um diesen anti-forensischen Methoden entgegenzuwirken, ist es wichtig:
Führen Sie eine gründliche Zeitachsenanalyse durch, indem Sie Tools wie Autopsy zur Visualisierung von Ereigniszeitachsen oder Sleuth Kit's
mactime
zur detaillierten Zeitachsenanalyse verwenden.Untersuchen Sie unerwartete Skripte im $PATH des Systems, die Shell- oder PHP-Skripte enthalten könnten, die von Angreifern verwendet werden.
Untersuchen Sie
/dev
nach untypischen Dateien, da es traditionell spezielle Dateien enthält, aber auch Dateien im Zusammenhang mit Malware enthalten kann.Suchen Sie nach versteckten Dateien oder Verzeichnissen mit Namen wie ".. " (Punkt Punkt Leerzeichen) oder "..^G" (Punkt Punkt Steuerung-G), die bösartigen Inhalt verbergen könnten.
Identifizieren Sie setuid-Root-Dateien mit dem Befehl:
find / -user root -perm -04000 -print
. Dies findet Dateien mit erhöhten Berechtigungen, die von Angreifern missbraucht werden könnten.Überprüfen Sie Löschzeitstempel in Inode-Tabellen, um Massenlöschungen von Dateien zu erkennen, die möglicherweise auf das Vorhandensein von Rootkits oder Trojanern hinweisen.
Inspezieren Sie aufeinanderfolgende Inodes auf nahegelegene bösartige Dateien nach der Identifizierung einer Datei, da sie möglicherweise zusammen platziert wurden.
Überprüfen Sie häufige binäre Verzeichnisse (/bin, /sbin) auf kürzlich geänderte Dateien, da diese von Malware verändert worden sein könnten.
Beachten Sie, dass ein Angreifer die Zeit ändern kann, um Dateien als legitim erscheinen zu lassen, aber er kann das Inode nicht ändern. Wenn Sie feststellen, dass eine Datei anzeigt, dass sie zur gleichen Zeit wie der Rest der Dateien im selben Ordner erstellt und geändert wurde, aber das Inode unerwartet größer ist, dann wurden die Zeitstempel dieser Datei geändert.
Vergleich von Dateien verschiedener Dateisystemversionen
Zusammenfassung des Dateisystemversionsvergleichs
Um Dateisystemversionen zu vergleichen und Änderungen zu ermitteln, verwenden wir vereinfachte git diff
-Befehle:
Um neue Dateien zu finden, vergleichen Sie zwei Verzeichnisse:
Für geänderte Inhalte Listen Sie Änderungen auf, wobei spezifische Zeilen ignoriert werden:
Zum Erkennen gelöschter Dateien:
Filteroptionen (
--diff-filter
) helfen dabei, Änderungen wie hinzugefügte (A
), gelöschte (D
) oder modifizierte (M
) Dateien einzugrenzen.A
: Hinzugefügte DateienC
: Kopierte DateienD
: Gelöschte DateienM
: Modifizierte DateienR
: Umbenannte DateienT
: Typänderungen (z. B. Datei zu Symlink)U
: Nicht zusammengeführte DateienX
: Unbekannte DateienB
: Defekte Dateien
Referenzen
Buch: Malware Forensics Field Guide für Linux-Systeme: Digitale Forensik-Feldführer
Verwenden Sie Trickest, um mithilfe der weltweit fortschrittlichsten Community-Tools einfach Workflows zu erstellen und zu automatisieren. Heute Zugriff erhalten:
Last updated