Verstehen Sie ganz einfach Ihre Linux-RAM-Nutzung mit Smem
Veröffentlicht: 2022-01-29
Die Linux-Speichernutzung kann schwierig zu interpretieren und schwer zu verstehen sein. Mit smem ist es einfach herauszufinden, welchen Speicher ein Prozess verwendet und welche Prozesse am meisten verwenden.
Speichernutzung
Linux bietet Ihnen viele Möglichkeiten, um zu überprüfen, was mit dem Arbeitsspeicher Ihres Computers passiert. Das Problem ist, dass die Speicherverwaltung eine komplizierte Herausforderung für Ihr Betriebssystem darstellt. Es muss mit physischem RAM, virtuellem RAM in Form von Auslagerungsspeicher und den Anforderungen der verschiedenen Arten von Prozessen, die gleichzeitig ausgeführt werden, jonglieren.
Prozesse verbrauchen RAM, wenn sie sich selbst in den Speicher laden. Sie fordern dann mehr RAM an, damit sie Platz haben, um alle Aufgaben auszuführen, für die sie entwickelt wurden. Einige Prozesse wirken sich kaum auf den Arbeitsspeicher aus, andere sind sehr speicherhungrig.
Der Kernel und der Rest des Betriebssystems, Ihre Desktop-Umgebung und jede Anwendung oder Befehlszeilensitzung, die Sie ausführen, verlangen alle nach einem Teil der begrenzten Menge an RAM, die in Ihrem Computer installiert ist. Einige Prozesse erzeugen andere Prozesse. Einige Prozesse teilen RAM mit anderen Prozessen.
Der Versuch, all dies zu entschlüsseln und eine einfache Antwort auf die Frage zu finden: „Wie viel RAM verwendet dieses Programm oder dieser Prozess?“ kann eine überraschende Herausforderung sein. Granularität ist großartig und hat ihren Platz, aber ebenso kann ein Overkill an Informationen ein Hindernis sein.
Wenn Sie beispielsweise mit cat einen Blick in das Pseudo-Dateisystem /proc/meminfo werfen, wurden 50 Zeilen der Ausgabe auf dem Computer zurückgegeben, auf dem dieser Artikel recherchiert wurde. Wo fängst du an?
cat /proc/meminfo
Und einige Linux-Dienstprogramme geben unterschiedliche Antworten. Auf unserer Testmaschine hatten wir eine less ausgeführte Instanz mit der Prozess-ID 2183.
Wir können das Dienstprogramm pmap mit der Option -x (erweitert) verwenden, um ein vollständiges Bild der Speichernutzung eines Prozesses zu erhalten. Wir verwenden es mit der Prozess-ID unserer Instanz von less :
pmap-x 2183

Am Ende der Ausgabe erhalten wir eine Summe für die Resident Set Size, die die Menge an verwendetem Haupt-RAM ist.

Wir haben dann das Dienstprogramm ps mit der Option -o (output) verwendet, die RSS Spalte ausgewählt und ihr die Prozess-ID derselben Instanz von less übergeben:
ps-oder rss 2183

Wir kommen zu einem anderen Ergebnis. Dies ist eine Designentscheidung seitens der ps -Autoren. Dies ist von der ps man :
Die Autoren anderer Dienstprogramme haben ihre eigenen Ansichten zum Messen der RAM-Nutzung.
Die RSS, die USS und die PSS
Die Resident Set Size (RSS) ist die Menge an RAM, die einem Prozess zugewiesen wird, ohne Auslagerungsspeicher, aber einschließlich jeglichem RAM, das von gemeinsam genutzten Bibliotheken benötigt wird, die der Prozess verwendet.
RSS berichtet fast immer über die RAM-Nutzung. Wenn zwei oder mehr Prozesse eine oder mehrere gemeinsam genutzte Bibliotheken verwenden, fügt RSS einfach die RAM-Nutzung jeder Bibliothek zu ihrer Zählung der RAM-Nutzung für jeden dieser Prozesse hinzu. Neben der Ungenauigkeit steckt darin eine gewisse Ironie. Gemeinsam genutzte Bibliotheken bedeuten, dass nicht jeder Prozess seine eigene private Instanz einer Bibliothek laden muss. Wenn sich die Bibliothek bereits im Speicher befindet, wird sie diese gemeinsam nutzen – und den RAM-Overhead reduzieren.
Die Proportional Set Size versucht, dies zu beheben, indem die Menge des gemeinsam genutzten Speichers auf die Prozesse aufgeteilt wird, die ihn gemeinsam nutzen. Wenn vier Prozesse Arbeitsspeicher gemeinsam nutzen, meldet PSS, dass 25 % des gemeinsam genutzten Arbeitsspeichers von jedem dieser Prozesse verwendet wird. Dies ist eine Annäherung, aber es ähnelt eher dem, was vor sich geht, als dem Bild, das RSS zeichnet.
Die eindeutige Satzgröße ist die RAM-Menge, die ausschließlich von einem Prozess verwendet wird, unabhängig davon, ob sie direkt von dem Prozess verbraucht wird oder von Bibliotheken verwendet wird, die ausschließlich von dem Prozess verwendet werden. Auch hier wird der Auslagerungsbereich ignoriert. Es ist nur an echtem, physikalischem RAM interessiert.
USS und PSS sind Begriffe und Konzepte, die von Matt Mackall, dem Autor von smem , vorgeschlagen wurden.
Das smem-Dienstprogramm
Das Dienstprogramm smem meldet den Speicher, der von Prozessen, Benutzern, Zuordnungen oder systemweit verwendet wird. Auf allen von uns getesteten Distributionen musste es installiert werden. Verwenden Sie diesen Befehl, um es unter Ubuntu zu installieren:
sudo apt installiere smem

Um smem auf Fedora zu installieren, müssen Sie Folgendes eingeben:
sudo dnf installiere smem

Um smem auf Manjaro zu installieren, verwenden Sie:
sudo pacman -Sy smem


Wenn smem ohne Optionen verwenden, erhalten Sie eine Liste der Prozesse, die RAM verwenden.
klein

Im Terminalfenster wird eine Tabelle mit Informationen angezeigt.

Die Spalten sind:
- PID : Die Prozess-ID des Prozesses, der den Speicher verwendet.
- Benutzer : Der Benutzername des Benutzers, dem der Prozess gehört.
- Command : Die Befehlszeile, die den Prozess gestartet hat.
- Swap : Wie viel Auslagerungsspeicher der Prozess verwendet.
- USS : Die einzigartige Set-Größe.
- PSS : Die proportionale Satzgröße.
- RSS : Die Resident Set Size.
Um die Größen in Prozent ausgedrückt anzuzeigen, verwenden Sie die Option -p (Prozent).
smem-p

Die Größen in Bytes wurden durch Prozentsätze ersetzt.

Um die Zahlen in einer menschenfreundlicheren Form anzuzeigen, verwenden Sie die Option -k (abkürzen). Dadurch werden die Zahlen verkleinert und Einheitenindikatoren hinzugefügt.
smem-k

Anstelle von Rohbytes werden die Größen in Megabyte, Gigabyte usw. angezeigt.

Um eine Summenzeile hinzuzufügen, verwenden Sie die Option -t (totals).
smem-k-t

Die letzte Zeile der Ausgabe zeigt Summen für jede Spalte.

Den Bericht verfeinern
Sie können smem bitten, über die Speichernutzung durch Benutzer, Mapping (Bibliotheken) oder systemweit zu berichten. Um die Ausgabe nach Benutzer zu filtern, verwenden Sie die Option -u (Benutzer). Beachten Sie, dass Sie smem mit sudo ausführen müssen, wenn Sie mehr als nur Ihre eigene Nutzung sehen möchten.
smem-u
sudo smem -u

Wie Sie sehen können, wird die Ausgabe bei Benutzernamen mit mehr als acht Zeichen verbogen.
Um die Nutzung anzuzeigen, die den verwendeten Bibliotheken zugeordnet ist, unabhängig davon, welche Prozesse die Bibliotheken verwenden oder welche Benutzer diese Prozesse besitzen, verwenden Sie die Option -m (Zuordnung).
smem -m -k -t

Wir haben auch nach menschenlesbaren Werten und einer Gesamtsumme gefragt.

Verwenden Sie die Option -w (systemweit), um die systemweite Speichernutzung anzuzeigen.
smem -w -k -t

Berichterstattung über ein einziges Programm
Mit ein wenig Befehlszeilenmagie können wir Berichte über ein einzelnes Programm und alle seine Unterprozesse erstellen. Wir leiten die Ausgabe von smem an tail weiter und bitten tail , nur die letzte Zeile anzuzeigen. Wir smem an, von Menschen lesbare Werte zu verwenden und eine Gesamtsumme bereitzustellen. Die Summe wird die letzte Zeile sein, und das ist das tail , das für uns angezeigt wird.
Wir verwenden die Option -c (Spalten) mit smem und teilen ihr mit, welche Spalten in unsere Ausgabe aufgenommen werden sollen. Wir beschränken dies auf die Spalte "Proportionale Satzgröße". Die Option -P (Prozessfilter) ermöglicht es uns, smem eine smem zu geben. Nur übereinstimmende Ausgabezeilen werden eingeschlossen.
smem -c pss -P firefox -k -t | Schwanz -n 1

Das ist eine schnelle und übersichtliche Methode, um den RAM-Verbrauch eines Programms und seiner untergeordneten Prozesse herauszufinden.
Diagramme generieren
Sie können die Optionen --pie oder --bar , damit smem Diagramme generiert. Es muss gesagt werden, dass bei zu vielen Kategorien die Grafiken schnell unverständlich werden, aber für einen schnellen visuellen Überblick können sie nützlich sein.
Das Befehlsformat ist:
smem --Kuchenname -s uss

Das Tortendiagramm wird in einem eigenen Viewer-Fenster angezeigt.

Um andere Diagramme anzuzeigen, verwenden pss oder rss anstelle von uss . Um ein Balkendiagramm anzuzeigen, verwenden --bar anstelle von --pie .
Damit dies funktioniert, müssen Sie Python zusammen mit der matplotlib Bibliothek installiert haben. Diese waren bereits auf den von uns getesteten Ubuntu-, Fedora- und Manjaro-Distributionen installiert.
Gutes kommt in kleinen Dosen
Das Dienstprogramm smem hat noch ein paar Tricks im Ärmel, und Sie werden ermutigt, sich seine man anzusehen. Sein Hauptrepertoire ist das, was wir hier skizziert haben, und es ist ein großartiges kleines Tool, das Sie in Ihrer CLI-Toolbox haben sollten.
VERWANDT: 37 Wichtige Linux-Befehle, die Sie kennen sollten



