BEZEICHNUNG

taskset - die CPU-Affinität eines Prozesses festlegen oder ermitteln

ÜBERSICHT

taskset [Optionen] Maske Befehl [Argument …]
 
taskset [Optionen] -p [Maske] PID

BESCHREIBUNG

Der Befehl taskset wird zum Ermitteln oder Festlegen der CPU-Affinität eines laufenden Prozesses verwendet, entweder durch Angabe der Prozesskennung ( PID) oder durch Ausführen eines neuen Befehls mit der angegebenen CPU-Affinität. Die CPU-Affinität ist eine Scheduler-Eigenschaft, die einen Prozess an eine gegebene CPU-Gruppe des Systems »bindet«. Der Linux-Scheduler respektiert die angegebene CPU-Affinität, so dass der Prozess nicht auf irgend einer anderen CPU ausgeführt wird. Beachten Sie, dass der Scheduler auch die natürliche CPU-Affinität unterstützt: der Scheduler versucht, Prozesse auf der gleichen CPU zu halten, solange es aus Leistungsgründen praktisch ist. Daher ist das Erzwingen einer spezifischen CPU-Affinität nur in bestimmten Anwendungsfällen sinnvoll.
 
Die CPU-Affinität wird in Form einer Bitmaske dargestellt, mit dem niedrigstwertigen Bit für die erste und dem höchstwertigen für die letzte logische CPU. Es müssen nicht alle CPUs auf einem System vorhanden sein, aber eine Maske kann mehr CPUs enthalten, als verfügbar sind. Eine ermittelte Bitmaske bildet nur jene CPUs ab, die tatsächlich physisch auf dem System vorhanden sind. Falls eine ungültige Maske angegeben wird (für die keine passenden CPUs auf dem System gefunden wurden), wird ein Fehler zurückgegeben. Die Masken können hexadezimal angegeben werden (mit oder ohne führendem »0x«) oder als CPU-Liste, die mit der Option --cpu-list angegeben wird. Zum Beispiel ist
 
0x00000001
der Prozessor #0,
 
0x00000003
sind die Prozessoren #0 und #1,
 
0xFFFFFFFF
sind die Prozessoren #0 bis #31,
 
32
sind die Prozessoren #1, #4 und #5,
 
--cpu-list 0-2,6
sind die Prozessoren #0, #1, #2 und #6.
 
--cpu-list 0-10:2
sind die Prozessoren #0, #2, #4, #6, #8 und #10. Das Suffix »:N« gibt die Schrittweite in dem Bereich an, zum Beispiel wird 0-10:3 als Liste von 0,3,6,9 interpretiert.
 
Wenn taskset etwas zurückgibt, dann ist garantiert, dass das gegebene Programm einer gültigen CPU zugeordnet wurde.

OPTIONEN

-a, --all-tasks
setzt oder ermittelt die CPU-Affinität aller Prozesse (Threads) für eine gegebene Prozesskennung (PID).
 
-c, --cpu-list
interpretiert Maske als numerische Liste von Prozessoren statt einer Bitmaske. Nummern werden durch Kommata getrennt und dürfen Bereichsangaben enthalten. Beispiel: 0,5,8-11.
 
-p, --pid
verwendet eine vorhandene Prozesskennung (PID), anstatt einen neuen Prozess zu starten.
 
-h, --help
zeigt einen Hilfetext an und beendet das Programm.
 
-V, --version
zeigt die Versionsnummer an und beendet das Programm.

VERWENDUNG

Per Vorgabe wird ein neuer Befehl mit der gegebenen Affinitätsmaske ausgeführt:
taskset Maske Befehl [Argumente]
 
Sie können auch die CPU-Affinität eines existierenden Prozesses ermitteln:
taskset -p PID
 
oder sie festlegen:
taskset -p Maske PID

ZUGRIFFSRECHTE

Ein Benutzer muss über CAP_SYS_NICE verfügen, um die CPU-Affinität eines Prozesses zu ändern. Die Ermittlung der Affinitätsmaske ist allen Benutzern erlaubt.

AUTOREN

Geschrieben von Robert M. Love. Copyright © 2004 Robert M. Love. Dies ist freie Software, in den Quellen finden Sie die Bedingungen zur Vervielfältigung und Weitergabe. Es gibt KEINE Garantie, auch nicht für die MARKTREIFE oder die TAUGLICHKEIT FÜR EINEN BESTIMMTEN ZWECK.

SIEHE AUCH

chrt(1), nice(1), renice(1), sched_getaffinity(2), sched_setaffinity(2)
 
In sched(7) finden Sie eine Beschreibung des Scheduling-Schemas in Linux.

FEHLER MELDEN

Verwenden Sie zum Melden von Fehlern das Fehlererfassungssystem auf <https://github.com/util-linux/util-linux/issues>.

VERFÜGBARKEIT

Der Befehl taskset ist Teil des Pakets util-linux, welches heruntergeladen werden kann von: Linux Kernel Archive <https://www.kernel.org/pub/linux/utils/util-linux/>.

ÜBERSETZUNG

Die deutsche Übersetzung dieser Handbuchseite wurde von Mario Blättermann <[email protected]> und Dr. Tobias Quathamer <[email protected]> erstellt.
Diese Übersetzung ist Freie Dokumentation; lesen Sie die GNU General Public License Version 3 oder neuer bezüglich der Copyright-Bedingungen. Es wird KEINE HAFTUNG übernommen.
Wenn Sie Fehler in der Übersetzung dieser Handbuchseite finden, schicken Sie bitte eine E-Mail an die Mailingliste der Übersetzer

Recommended readings

Pages related to taskset you should read also: