Home / LinuxUser / 2004 / 02 / Zu Befehl: su, sudo

Newsletter abonnieren

Lies uns auf...

Folge LinuxCommunity auf Twitter

Top-Beiträge

War doch klar...
(229 Punkte bei 11 Stimmen)
Pardus Linux am Ende?
(201 Punkte bei 6 Stimmen)
Meinst Du: Patch CD Updates?
(179 Punkte bei 5 Stimmen)
One goes, one comes
(161 Punkte bei 4 Stimmen)
Speichern in der Cloud
(161 Punkte bei 4 Stimmen)

Heftarchiv

LinuxUser Heftarchiv

EasyLinux Heftarchiv

Ubuntu User Heftarchiv

Ubuntu User Heftarchiv

Partner-Links:

Shopping
Topsuche
 
Yatego Deutschlands größte Shoppingmall. 10000 Shops,
3.5 Mio Artikel. Alle Bestseller, Servertechnik und Technik Themenwelten.

Notebooks und Netzwerkhardware bei Mercateo günstig kaufen.
Internet Telefonie mit VoIP Telefonen von Gigaset
Das B2B Portal www.Linx.de informiert über Produkte und Dienstleistungen.
Günstige Digitalkameras finden Sie im Preisvergleich.

Neue Identität

Zu Befehl: su, sudo

01.02.2004 Sicher ist sicher – selbst wer Root-Rechte auf dem System hat, sollte nur temporär als Administrator arbeiten, um nicht aus Versehen Schaden anzurichten. Mit su und sudo wechseln Sie auf der Kommandozeile schnell die Identität.

Zu Befehl

Auch wenn sich viele Dinge bequem über grafische Oberflächen wie KDE oder GNOME regeln lassen – wer sein Linux-System richtig ausreizen möchte, kommt um die Kommandozeile nicht herum. Abgesehen davon gibt es auch sonst viele Situationen, in denen es gut ist, sich im Befehlszeilendschungel ein wenig auszukennen.

Administrative Aufgaben verlangen Root-Rechte. Es ist aber nicht immer sinnvoll, als Administrator zu arbeiten. Besser ist es, lediglich für die jeweilige Aufgabe root zu werden und danach als "normaler" User weiterzuarbeiten. Mit den Befehlen su und sudo wechseln Sie die Identität.

Wie Du mir, su ich Dir…

Mit dem Kommando su ("substitute user") wechseln Sie auf der Kommandozeile die Identität. Dazu startet im Hintergrund eine neue Shell unter einer neuen Benutzerkennung (UID) und Gruppenkennung (GID). Um mit su Administrator oder ein anderer Benutzer zu werden, müssen Sie das entsprechende Passwort kennen.

Grundsätzlich lautet das Kommando su [-] [benutzername] – dabei gibt es den kleinen aber feinen Unterschied, ob Sie das Minuszeichen verwenden oder nicht. Das Minuszeichen (alternativ können Sie hier den Parameter -l oder seine Langform --login verwenden) sorgt dafür, dass ein wirkliches Einloggen stattfindet – mit Setzen der richtigen Umgebungsvariablen, Shell und einem Wechsel in das neue Home-Verzeichnis. Ohne das Minuszeichen ändern sich die Umgebungsvariablen nicht, und der neue User besitzt eventuell keine Rechte, sich im aktuellen Arbeitsverzeichnis aufzuhalten (Abbildung 1).

Abbildung 1: Ohne richtiges Login gibt es manchmal kein Aufenthaltsrecht

Ohne Angabe eines Benutzernamens werden Sie zum Administrator root. Dieses Feature führt dazu, dass su oft fälschlicherweise "Super-User"-Kommando genannt wird.

Standardmäßig erlaubt die Verwendung von su dem neuen Benutzer aber nicht, X-Anwendungen zu starten. Einem "fremden" Benutzer muss zunächst erlaubt werden, den X-Server zur Ausgabe zu benutzen. Eine solche Erlaubnis erteilen Sie über die Datei .Xauthority im Home-Verzeichnis (siehe auch man xauth). Um dem Benutzer root zu erlauben, aus einem Xterm, das eigentlich dem User petronella gehört, ein X-Programm zu starten, müssen Sie einen passenden "Schlüssel" aus .Xauthority extrahieren, der .Xauthority des Administrators hinzufügen und danach die DISPLAY-Variable neu setzen (Listing 1).

Listing 1

petronella@asteroid:~$ xauth extract schluessel $DISPLAY
huhn@asteroid:~$ su - 
Password:
asteroid:~# xauth merge /home/huhn/schluessel
asteroid:~# export DISPLAY=:0.0

Mit su ist es darüber hinaus möglich, ein einziges Kommando unter fremder Identität zu starten. Dazu verwenden Sie die Option -c (--commmand):

huhn@asteroid:~$ su -c "less /var/log/messages"
Password:

Die Benutzung des su-Kommandos wird protokolliert. Je nach Distribution finden sich diese Log-Einträge in der Datei /var/log/auth.log (z. B. Debian) oder auch /var/log/messages (z. B. SuSE Linux). Fehlgeschlagene Versuche sind deutlich zu erkennen – so finden Sie als Administrator schnell heraus, dass jemand versucht hat, Root-Rechte zu erlangen:

Dec 22 14:50:50 asteroid PAM_unix[2108]: authentication failure;
(uid=500) -> root for su service
Dec 22 14:50:52 asteroid su[2108]: pam_authenticate: Authentication
failure
Dec 22 14:50:52 asteroid su[2108]: - pts/8 huhn-root

Als Administrator müssen Sie nach dem su-Befehl übrigens kein Passwort eingeben – Sie können jede beliebige Identität annehmen, um beispielsweise schnell etwas aus Sicht eines bestimmten Anwenders zu testen.

Do the sudo

Wer aus Sicherheitsgründen das Root-Passwort des Rechners nicht weitergeben möchte, setzt einfach das Programm sudo ein. Der Name ist Programm: "sudo" steht für "substitute user, do" und gibt einzelnen Benutzern oder Gruppen für einen begrenzten Zeitraum oder für immer Administratorrechte, aber nur für spezielle Aufgaben. Anstelle des Root-Passwortes benutzt der Anwender sein eigenes Kennwort, um einen privilegierten Befehl auszuführen.

Dazu trägt der Administrator in die Datei /etc/sudoers ein, welcher Anwender bestimmte Befehle auf dem Computer ausführen darf. Diese Datei sollten Sie (als root) in jedem Fall mit dem Kommando visudo editieren – dieses Programm bietet die gewohnten Features des Editors vi zusammen mit ein paar zusätzlichen Funktionen. visudo "sperrt" die Datei /etc/sudoers, so dass sie nicht aus Versehen zwei Benutzer gleichzeitig editieren. Außerdem prüft visudo beim Beenden des Editors die Syntax der Datei und meldet eventuelle Fehler:

>>> sudoers file: syntax error, line 20 <<<
What now?

Drei Möglichkeiten stehen nun zur Wahl: Tippen Sie e, um die Datei erneut zu editieren, x, um die Änderungen zu verwerfen und den Editor zu verlassen, und Q, um die Änderungen trotzdem zu speichern.

Als Standardeintrag findet sich in /etc/sudoers root ALL=(ALL) ALL – der Administrator darf alles. (Aber das kann er eh, auch ohne sudo.) Wer einem weiteren Benutzer auf dem System uneingeschränkte Root-Rechte geben möchte, kopiert die Zeile und setzt statt root den anderen Benutzernamen ein. Anschließend darf dieser Benutzer Administratorkommandos mit vorangestelltem sudo ausführen, z. B.:

huhn@asteroid:~$ sudo /sbin/shutdown
Password:

Ist der User nicht zur Verwendung von sudo berechtigt, meldet sudo: huhn is not in the sudoers file. This incident will be reported. Sofern nicht anders in /etc/sudoers definiert, erhält der Administrator eine Mail mit genauen Angaben, welcher Benutzer wann versucht hat, sudo aufzurufen (Abbildung 2). Zur Sicherheit rufen Sie als einfacher User sudo -l auf, um eine Liste der erlaubten Kommandos zu erhalten.

Abbildung 2: Sicherheit wird groß geschrieben – sudo meldet unerlaubten Zugriff

Einem Freund empfehlen    Druckansicht Bookmark and Share
Kommentare

2926 Hits
Wertung: 0 Punkte (1 Stimme)

Schlecht Gut

Infos zur Publikation

Infos zur Publikation

title_2012_02

Aktuelle Ausgabe kaufen:

Heft bestellen Heft als PDF kaufen

LinuxUser erscheint monatlich und kostet in der Nomedia-Ausgabe EUR 5,50 und mit DVD EUR 8,50. Weitere Informationen zum Heft finden Sie auf der LinuxUser-Homepage.

Im LinuxUser-Probeabo erhalten Sie drei Ausgaben für 3 Euro. Das Jahresabo (ab EUR 56,10) können Sie im LNM-Shop bestellen.

Tipp der Woche

Duden Korrektor unter 64-Bit
Duden Korrektor unter 64-Bit
Tim Schürmann, 06.02.2012 10:36, 0 Kommentare

Der Duden Korrektor bietet eine äußerst nützliche Rechtschreib- und Grammatikkorrektur für LibreOffice und bringt in der aktuellen Version 8 e...

Aktuelle Fragen

rndc reload zone - failed bad zone
Ludwig jun. B., 06.02.2012 16:08, 2 Antworten
Schönen guten Tag, ich habe folgendes Problem. Immer wenn ich folgendes Kommando ausführen bek...
Skype für 64-Bit-Prozessor u. Suse 12.1
Klaus Sigerist, 05.02.2012 11:39, 3 Antworten
Hallo Gemeinde! Ich bin nur ein einfacher Nutzer und habe Probleme mit der Installation von Skyp...
8! Anfängerfrage :) Wie finde ich in Ubuntu die Datenträger (Bild, Text)
samuel leusam, 04.02.2012 15:53, 1 Antworten
Ich habe neu Ubuntu. Wenn ich die SD Karte im Laptop einstecke, erkennt er sie und gibt ihr den N...
OpenSuse 12.1-Service Kit 01/12
Christoph-J. Walter, 28.01.2012 08:52, 2 Antworten
Hallo Gemeinde, ich habe 12.1 neu installiert. Alles in Ordnung! Nun möchte ich das Service Kit (...
Ubuntu 11.10 konfigurieren
Michael Hinz, 27.01.2012 17:52, 1 Antworten
Ubuntu läuft bei mir. Allerdings nur, wenn die Daten-CD eingelegt ist. Unabhängig von Bios-Einste...