<p><imgsrc="../images/processcontroller-images/applet.png"alt="ProcessController applet"style="float:left;margin: 0 1em 0 0"/>Hauptaufgabe von ProcessController ist die Anzeige von Prozessorauslastung und Speichernutzung. Außerdem können einzelne Teams überwacht und ihre Priorität geändert, oder auch zum Beenden gezwungen werden, falls ein Programm hängt. Bei Multiprozessorsystemen können sogar einzelne CPUs/Cores abgeschaltet werden. Zusätzlich können Tracker und Deskbar aus dem Menü komfortabel neu gestartet werden, sollten sie mal abgestürtzt sein.</p>
<p>Die Balken links zeigen die Auslastung jeder CPU, rechts befindet sich ein Balken zur Speicherauslastung. Die Zahl der Balken hängt natürlich von der Anzahl an CPUs/Cores des Rechners ab.</p>
<p>Wenn das Programm nicht schon läuft, kann man beim Start entscheiden, ob das Applet in einem Fenster laufen oder in die Deskbar installiert werden soll. Im Fenstermodus kann die Balkengröße geändert werden, indem man die Fenstergröße anpasst, bevor man es am <ahref="../gui.html#replicants">Replikanten</a>-Symbol packt und auf den Desktop zieht.<br/>
Wo das Applet auch installiert ist, bedient wird es per Rechtsklick über ein Kontextmenü.<br/>
Um es wieder aus der Deskbar zu entfernen, deaktiviert man mit dem Kontextmenü die Option <spanclass="menu">In der Deskbar laufen</span>.</p>
<p>Um eine Anwendung zu beenden, wählt man einfach deren Namen aus dem Menü <spanclass="menu">Anwendung beenden</span>. Dadurch wird eine Anwendung sauber geschlossen, genauso als hätte man den Schließen-Button des Fensters geklickt. Besonders vorsichtig sollte man allerdings mit Systemprozessen wie Server und Daemons sein. Werden sie beendet, läuft das System eventuell nicht mehr stabil oder zumindest nicht mehr wie gewohnt.</p>
<p>Die Überwachung der Speichernutzung kann ziemlich ungenau sein.</p>
<p>Das Menü ermöglicht die Überwachung der Speichernutzung der diversen Teams im System. Neben dem Team-Name befinden sich zwei Spalten: die erste enthält den Speicher, der schreibend reserviert wurde, während die zweite den Gesamtspeicherbedarf zeigt, also inklusive nur lesend genutzten Speicher (von gemeinsam genutzte Bibliotheken, beispielsweise).</p>
<p>Die oberste Zeile <i>Systemressourcen & Cache</i> zeigt die gesamte Speichernutzung von System und allen Anwendungen. Die Länge des blauen Balkens repräsentiert dden physikalisch im Rechner vorhandenen Speicher. Die folgenden Reihen zeigen den benutzten Speicher für jedes Team. Die Länge der Balken entspricht nur dem tatsächlich benutzten Teil des Speichers.</p>
<p>Mit diesem Menü lassen sich Thread-Prioritäten ändern und Teams zum Beenden zwingen oder debuggen.</p>
<divclass="box-stop">Änderungen durch Befehle aus diesem Menü greifen tief in das System ein und können zu Datenverlust und einem instabilen System führen. Hier ist eine ruhige Maushand gefragt!</div>
<p>Auf der ersten Ebene befinden sich die Team-Namen. Klickt man auf einen, kann das gesamte Team zum Beenden gezwungen werden. Der dunkelblaue Teil des Balkens entspricht der Zeit, die in Kernel-Code verbracht wird, der hellblaue Teil in User-Code, und der grüne Teil in den Leerlauf-Thread(s). Ein komplett blauer Balken bedeutet, dass dieses Team die gesamte Rechenleistung beansprucht.</p>
<p>Die zweite Ebene zeigt alle Threads eines Teams. Klickt man auf einen, kann er debugged oder zum Beenden gezwungen werden. Ein komplett blauer Balken bedeutet, dass dieser Thread einen Prozessor/Kern vollständig auslastet.</p>
<p>In der letzten Ebene des Menüs lässt sie die Priorität eines Threads ändern. Hier ist Vorsicht angesagt! In der Regel sollte die Priorität eines Threads umgekehrt zu seiner CPU-Auslastung sein. Das heißt, je mehr er versucht Rechenzeit zu bekommen, desto niedriger sollte seine Priorität sein. Am besten man spielt gar nicht erst mit Thread-Prioritäten einer Anwendung herum, sondern kontaktiert statt dessen deren Autoren; das ist deren Aufgabe.</p>