Provided by: util-linux-locales_2.40.2-1ubuntu2_all
JMÉNO
su - spustí shell pod jiným uživatelským a skupinovým ID
POUŽITÍ
su [options] [-] [user [argument...]]
POPIS
su allows commands to be run with a substitute user and group ID. Je-li zavolán bez udání uživatele, su spustí interaktivní shell jako root. Je-li uživatel zadán, lze zadat další argumenty a ty budou v takovém případě předány shellu. Z důvodu zpětné kompatibility su ve výchozí podobě nemění pracovní adresář a z proměnných prostředí pouze změní HOME a SHELL (a USER a LOGNAME, není-li cílový uživatel root). Doporučuje se vždy použít přepínač --login (namísto jeho zkratky -), aby se zamezilo vedlejším účinkům způsobeným pomícháním prostředí. Tato verze su používá pro autentizaci, autorizaci a správu relace PAM. Některé možnosti nastavení nacházející se v jiných implementacích su, jako podpora skupiny wheel, se musí nastavit přes PAM. su is mostly designed for unprivileged users, the recommended solution for privileged users (e.g., scripts executed by root) is to use non-set-user-ID command runuser(1) that does not require authentication and provides separate PAM configuration. If the PAM session is not required at all then the recommended solution is to use command setpriv(1). Pamatujte, že su ve všech případech používá PAM (pam_getenvlist(3)), aby upravil konečné prostředí. Přepínače příkazové řádky jako --login nebo --preserve-environment ovlivňují prostředí před tím, než je změněno systémem PAM. Od verze 2.38 su resetuje omezení zdrojů procesu RLIMIT_NICE, RLIMIT_RTPRIO, RLIMIT_FSIZE, RLIMIT_AS a RLIMIT_NOFILE.
VOLBY
-c, --command=příkaz Předá příkaz shellu pomocí přepínače -c. -f, --fast Předá shellu -f, což může, nebo nemusí být užitečné v závislosti na shellu. -g, --group=skupina Určuje primární skupinu. Tento přepínač je dostupný pouze uživateli root. -G, --supp-group=skupina Určuje doplňkovou skupinu. Tento přepínač je dostupný pouze uživateli root. První zadaná doplňková skupina se rovněž použije jako primární skupina, nebyl-li zadán přepínač --group. -, -l, --login Start the shell as a login shell with an environment similar to a real login. Note that on systemd-based systems, a new session may be defined as a real entry point to the system. However, su does not create a real session (by PAM) from this point of view. You need to use tools like systemd-run or machinectl to initiate a complete, real session. su does: • vyčistí všechny proměnné prostředí kromě TERM a proměnných zadaných v --whitelist-environment • inicializuje proměnné prostředí HOME, SHELL, USER, LOGNAME a PATH • přejde do domovského adresáře cílového uživatele • nastaví argv[0] shellu na '-', aby se shell stal shellem přihlašovacím -m, -p, --preserve-environment Zachová celé prostředí. Tj. nenastaví HOME, SHELL, USER, ani LOGNAME. Tento přepínač se ignoruje, byl-li uveden přepínač --login. -P, --pty Pro relaci vytvoří pseudoterminál. Nezávislý terminál poskytuje větší bezpečí, neboť uživatel nesdílí terminál s původní relací. Toho lze využít k zabránění vložení řídícího volání TIOCSTI terminálu a jiným bezpečnostním útokům na deskriptory souboru terminálu. Rovněž celou relaci je možné přesunout na pozadí (např. su --pty - uživatel -c aplikace &). Je-li pseudoterminál zapnut, pak su bude pracovat jako prostředník mezi relacemi (synchronizovat standardní vstup a výstup). Tato funkce je převážně navržena pro interaktivní relace. Pokud standardní vstup není terminál, ale například rourou (př. echo "date" | su --pty), pak příznak ECHO pseudoterminálu bude vypnut, aby se předešlo zaneřádění výstupu. -s, --shell=shell Run the specified shell instead of the default. If the target user has a restricted shell (i.e., not listed in /etc/shells), the --shell option and the SHELL environment variables are ignored unless the calling user is root. The shell to run is selected according to the following rules, in order: • shell zadaný pomocí --shell • shell určený proměnnou prostředí SHELL, je-li použit přepínač --preserve-environment • shell uvedený v záznamu passwd cílového uživatele • /bin/sh --session-command=příkaz Stejné jako -c, ale nevytvoří novou relaci. (Nedoporučuje se.) -T, --no-pty* Do not create a pseudo-terminal, opposite of --pty and -P. Note that running without a pseudo-terminal opens the security risk of privilege escalation through TIOCSTI/TIOCLINUX ioctl command injection. -w, --whitelist-environment=seznam Neresetuje proměnné prostředí uvedené v čárkou odděleném seznamu, když se čistí prostředí pro --login. Tento seznam se ignoruje pro proměnné prostředí HOME, SHELL, USER, LOGNAME a PATH. -h, --help Zobrazí text nápovědy a skončí. -V, --version Zobrazí verzi a skončí.
SIGNÁLY
Po přijetí signálu SIGINT, SIGQUIT nebo SIGTERM su ukončí svého potomka a poté ukončí sebe přijatým signálem. Potomek bude ukončen signálem SIGTERM. Při neúspěšném pokusu bude po 2 sekundách prodlení potomek zabit signálem SIGKILL.
KONFIGURAČNÍ SOUBORY
su reads the /etc/default/su and /etc/login.defs configuration files. The following configuration items are relevant for su: FAIL_DELAY (číslo) Zpoždění v sekundách v případě selhání přihlášení. Hodnota musí být nezáporné celé číslo. ENV_PATH (řetězec) Určuje proměnnou prostředí PATH pro běžné uživatele. Výchozí hodnota je /usr/local/bin:/bin:/usr/bin. ENV_ROOTPATH (řetězec), ENV_SUPATH (řetězec) Určuje proměnnou prostředí PATH pro uživatele root. ENV_SUPATH má přednost. Výchozí hodnota je /usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin. ALWAYS_SET_PATH (pravdivostní hodnota) Je-li nastaveno na yes a --login a --preserve-environment nebyly-li zadány, su inicializuje PATH. Proměnná prostředí PATH se může lišit na systémech, kde /bin a /sbin jsou začleněny do /usr. Tato proměnná je rovněž ovlivněna přepínačem příkazové řádky --login a nastavením systému PAM (např. pam_env(8)).
NÁVRATOVÁ HODNOTA
su normally returns the exit status of the command it executed. If the command was killed by a signal, su returns the number of the signal plus 128. Návratová hodnota vyrobená nástrojem su samotným: 1 Obecná chyba před spuštěním požadovaného příkazu 126 Požadovaný příkaz nebylo možné spustit 127 Požadovaný příkaz nebyl nalezen
SOUBORY
/etc/pam.d/su výchozí konfigurační soubor PAM /etc/pam.d/su-l konfigurační soubor PAM, byl-li zadán --login /etc/default/su konfigurační soubor logindef určený tento nástroj /etc/login.defs globální konfigurační soubor logindef
POZNÁMKY
Z bezpečnostních důvodů su vždy zaprotokoluje selhané pokusy o přihlášení to souboru btmp, avšak vůbec nezapisuje do souboru lastlog. Následující řešení pomocí nastavení PAM lze použít k ovlivnění chování su. Chcete-li používat modul pam_lastlog(8) pro vypisování varování o selhaných přihlašovacích pokusech, pak pam_lastlog(8) musí být nastaven tak, aby rovněž aktualizoval soubor lastlog. Například: session required pam_lastlog.so nowtmp
HISTORIE
Tento nástroj su byl odvozen z su v balíku coreutils, který byl založen na implementaci Davida MacKenzie. Verze v util-linux byl přepsána Karlem Žákem.
DALŠÍ INFORMACE
setpriv(1), login.defs(5), shells(5), pam(8), runuser(1)
HLÁŠENÍ CHYB
Pro hlášení chyb (anglicky) použijte systém pro sledování problémů na https://github.com/util-linux/util-linux/issues.
TIRÁŽ
Příkaz su je součástí balíku util-linux, který lze stáhnout z archivu jádra Linuxu <https://www.kernel.org/pub/linux/utils/util-linux/>.