| environ(7) | Miscellaneous Information Manual | environ(7) |
environ - środowisko użytkownika
extern char **environ;
Zmienna environ wskazuje na tablicę łańcuchów zwaną "środowiskiem". Ostatni wskaźnik w tej tablicy musi mieć wartość NULL. Ta tablica łańcuchów udostępniana jest procesowi przez funkcję execve(2) podczas uruchamiania nowego programu. Gdy proces potomny jest tworzony przez fork(2), dziedziczy copy ze środowiska swojego rodzica.
Zgodnie z konwencją, łańcuch w environ ma postać "nazwa=wartość". Nazwa jest wrażliwa na wielkość liter i nie może zawierać znaku równości "=". Wartość może być wszystkim co można zapisać jako łańcuch tekstowy. Nazwa i wartość nie mogą zawierać bajtu zerowego ("\0"), gdyż służy on do zakończenia łańcucha.
Zmienne środowiskowe mogą być umieszczane w środowisku powłoki poleceniem export w sh(1) lub setenv jeśli korzysta się z csh(1).
Na początkowe środowisko powłoki ma wpływ wiele czynników, takich jak definicje z /etc/environment przetwarzane dla wszystkich użytkowników przy logowaniu przez pam_env(8) (w systemach korzystających z pam(8)). Dodatkowo wiele inicjalizacyjnych skryptów powłoki, takich jak systemowy skrypt /etc/profile i skrypty inicjalizacyjne użytkowników mogą zawierać polecenia dodające zmienne do środowiska powłoki; proszę zapoznać się z podręcznikiem systemowym swojej powłoki, aby dowiedzieć się więcej.
Powłoki wzorowane na powłoce Bourne'a obsługują składnię
NAZWA=wartość polecenie
aby zdefiniować zmienną środowiskową wyłącznie w zakresie procesu wykonującego polecenie. Przed poleceniem można podać wiele definicji, oddzielonych białym znakiem.
W środowisku mogą być również umieszczane argumenty w momencie wykonywania funkcji exec(3). Program napisany w C może manipulować środowiskiem za pomocą funkcji getenv(3), putenv(3), setenv(3) i unsetenv(3).
Poniżej przedstawiono listę zmiennych środowiskowych występujących zwykle w systemie. Jest niekompletna i zawiera wyłącznie powszechne zmienne spotykane na co dzień przez przeciętnego użytkownika. Zmienne środowiskowe przypisane określonemu programowi lub funkcji bibliotecznej opisano w rozdziale ŚRODOWISKO właściwego podręcznika systemowego.
Trzeba zauważyć, że obecność lub wartości pewnych zmiennych środowiska mają wpływ na zachowanie wielu programów i funkcji bibliotecznych. Oto przykłady:
Historycznie i w zgodności ze standardem, environ musi być zadeklarowane w programie użytkownika. Jednak dla wygody programisty environ jest (niestandardowo) deklarowane w nagłówku pliku <unistd.h> jeśli zdefiniowane jest testowe makro _GNU_SOURCE (zob. feature_test_macros(7)).
Operacje PR_SET_MM_ENV_START i PR_SET_MM_ENV_END prctl(2) mogą posłużyć do kontroli położenia środowiska procesu.
Zmienne HOME, LOGNAME, SHELL i USER są ustawiane gdy dochodzi do zmiany użytkownika, za pomocą interfejsu zarządzania sesją, zwykle przez program typu login(1), na takiego z bazy danych użytkowników (np. passwd(5)). Przełączenie na użytkownika root za pomocą su(1) może skutkować mieszanym środowiskiem, gdy LOGNAME i USER pochodzą jeszcze od starego użytkownika; zob. stronę podręcznika systemowego su(1).
Oczywiście istnieje tu ryzyko naruszenia bezpieczeństwa. Wiele poleceń systemowych zostało oszukanych w celu wyrządzenia szkody przez użytkownika, który nadał nietypowe wartości zmiennym IFS lub LD_LIBRARY_PATH.
Istnieje również ryzyko skażenia przestrzeni nazw. Programy takie jak make i autoconf pozwalają na nadpisywanie domyślnych nazw programów narzędziowych poprzez środowisko zawierające zmienne o nazwach podobnych do nazw tych programów, ale składających się wyłącznie z wielkich liter. Zatem używa się CC do określenia pożądanego kompilatora C (i podobnie MAKE, AR, AS, FC, LD, LEX, RM, YACC itd.). Jednakże, w niektórych tradycyjnych zastosowaniach takie zmienne środowiskowe podają opcje dla programów zamiast ścieżki. Zatem mamy MORE i LESS. Takie zastosowanie jest traktowane jako błędne i należy go unikać w nowych programach.
bash(1), csh(1), env(1), login(1), printenv(1), sh(1), su(1), tcsh(1), execve(2), clearenv(3), exec(3), getenv(3), putenv(3), setenv(3), unsetenv(3), locale(7), ld.so(8), pam_env(8)
Tłumaczenie niniejszej strony podręcznika: Przemek Borys <pborys@dione.ids.pl>, Robert Luberda <robert@debian.org> i Michał Kułach <michal.kulach@gmail.com>
Niniejsze tłumaczenie jest wolną dokumentacją. Bliższe informacje o warunkach licencji można uzyskać zapoznając się z GNU General Public License w wersji 3 lub nowszej. Nie przyjmuje się ŻADNEJ ODPOWIEDZIALNOŚCI.
Błędy w tłumaczeniu strony podręcznika prosimy zgłaszać na adres listy dyskusyjnej manpages-pl-list@lists.sourceforge.net.
| 15 czerwca 2024 r. | Linux man-pages 6.9.1 |