Setgid

Setgid (Set Group ID, manchmal auch SGID) ist ein (erweitertes) Unix-Dateirecht für Dateien oder Verzeichnisse des Unix-Betriebssystems. Ausführbare Programme, bei denen dieses Bit gesetzt ist, werden neben den Rechten des ausführenden Benutzers zusätzlich mit den Rechten der Gruppe, welcher das Programm gehört, ausgeführt.

Auf manchen Systemen bewirkt das Setgid-Bit bei einem Verzeichnis, dass darin neu angelegte Dateien oder Unterverzeichnisse der Gruppe angehören, der auch das Verzeichnis angehört (statt der Gruppe, zu der der erstellende Benutzer gehört).

Setzen des SGID-Bits

Mit Dateimanagern kann das Bit per Klick gesetzt werden

Mit klassischen Unix-Kommandos wie chmod kann das Bit mit einem Aufruf wie

chmod g+s objekt

gesetzt werden, wobei objekt für mindestens eine Datei bzw. Verzeichnis steht.

Auch moderne Dateimanager bieten Möglichkeiten, das Bit graphisch per Checkbox zu aktivieren/deaktivieren.

Notation/Anzeige des Bits

In der erweiterten Oktalnotation, die sich vier Oktalziffern bedient, repräsentiert die Addition des Wertes 2 auf die erste Ziffer das gesetzte Setgid-Bit. Eine Datei mit den Rechten 0755 (in Oktalschreibweise) hat nach Setzen des Setgid-Bits die Rechte 2755. Diese Darstellung ist offensichtlich unabhängig davon, ob die Datei für die Gruppe ausführbar ist.

Die symbolische Rechtenotation hingegen unterscheidet zwischen gesetztem SGID-Bit, indem an der Stelle, die die Gruppenausführbarkeit repräsentiert, statt x ein s und statt - ein S steht. So wird aus rwxr-xr-x nach Setzen des Setgid-Bits rwxr-sr-x, aus rw-r--r-- hingegen rw-r-Sr--.

Wirkung des gesetzten Bits auf Verzeichnisse

Da Verzeichnisse nicht im herkömmlichen Sinne ausgeführt (executed) werden können, hat das SGID-Bit hier eine besondere Bedeutung. Setzt man hier nämlich das SGID-Bit, werden die Gruppen in den Unterverzeichnissen vererbt.

Das SGID-Bit stellt in dieser Konfiguration kein Sicherheitsrisiko dar, solange es nicht auf Dateien angewendet wird.

Beispiel

Zunächst ohne SGID-Bit:

# ls -l /data/fileshare
drwxrwx--- admin   abteilung1  1994-05-23 daten_abteilung1
drwxrwx--- admin   abteilung2  1994-05-23 daten_abteilung2
drwxrwx--- admin   abteilung3  1994-05-23 daten_abteilung3

(Hinweis zur Bedeutung der Spalten von links nach rechts: Rechte, Besitzer, Gruppe, Datum, Name.)
Werden hier neue Dateien angelegt, wird die primäre Gruppe des gerade angemeldeten Benutzers als Gruppe für eine neue Datei gesetzt.

# ls -l /data/fileshare/daten_abteilung1
-rw-rw---- mueller   abteilung1  1994-05-23 datei1.txt
-rw-rw---- wieser    abteilung1  1994-05-23 datei2.txt
-rw-rw---- maier     abteilung1  1994-05-23 datei3.png

Ist Hr. Maier aber auch Mitglied von abteilung2, können Dateien, die von Hr. Maier erstellt wurden, nicht mehr von den Kollegen aus abteilung2 gelesen werden, da die primäre Gruppe auf abteilung1 gesetzt bleibt.

# ls -l /data/fileshare/daten_abteilung2
-rw-rw---- maier     abteilung1  1994-05-23 maiers_datei.txt
-rw-rw---- berger    abteilung2  1994-05-23 datei2.txt
-rw-rw---- berger    abteilung2  1994-05-23 datei3.txt

Wenn man aber das SGID-Bit auf die übergeordneten Verzeichnisse setzt, wird die Gruppe vererbt. Dadurch ist es möglich, verschiedene Abteilungen zu verwalten, ohne auf komplexe ACLs angewiesen zu sein oder Berechtigungen für jedermann vergeben zu müssen.

# find /data/fileshare/* -type d -exec chmod g+s {} \;

(Dieses Kommando sucht nach allen Verzeichnissen und setzt das SGID-Bit)

Wird jetzt eine Datei von Hr. Maier in abteilung2 erstellt, kann diese jetzt auch von den anderen Mitgliedern der abteilung2 bearbeitet werden:

#maier$ touch /data/fileshare/daten_abteilung2/maiers_datei.txt
# ls -l /data/fileshare
drwxrws--- admin   abteilung1  1994-05-23 daten_abteilung1
drwxrws--- admin   abteilung2  1994-05-23 daten_abteilung2
drwxrws--- admin   abteilung3  1994-05-23 daten_abteilung3
# ls -l /data/fileshare/daten_abteilung2 
-rw-rw---- maier     abteilung2  1994-05-23 maiers_datei.txt
-rw-rw---- berger    abteilung2  1994-05-23 datei2.txt
-rw-rw---- berger    abteilung2  1994-05-23 datei3.txt

Sicherheitsaspekt

Obwohl in vielen Situationen sehr nützlich, kann das Setgid-Bit (ähnlich dem Setuid-Bit) ein hohes Sicherheitsrisiko bedeuten, wenn bei Programmen Setgid gesetzt wird, die unsicher programmiert sind.

Siehe auch

Auf dieser Seite verwendete Medien

Konqueror file permissions.png
Autor/Urheber: User:Sven, Lizenz: GPL
This screenshot shows a (German localized) Konqueror with the file permissions dialog in front of the ordinary file settings dialog. Konqueror is GPL.