Jądro systemu operacyjnego: Różnice pomiędzy wersjami

Z Wikipedii, wolnej encyklopedii
[wersja nieprzejrzana][wersja przejrzana]
Usunięta treść Dodana treść
Nie podano opisu zmian
Znaczniki: Ręczne wycofanie zmian Wycofane Z urządzenia mobilnego Z wersji mobilnej (przeglądarkowej)
Anulowanie wersji 64902287 autorstwa 31.0.59.92 (dyskusja)
Znacznik: Anulowanie edycji
Linia 1: Linia 1:
{{Dopracować|źródła=2012-08}}
{{wikisłownik|jądro}}
'''Jądro systemu operacyjnego''' ({{ang.|kernel}}) – podstawowa część [[system operacyjny|systemu operacyjnego]], która jest odpowiedzialna za wszystkie jego zadania.

== Budowa jądra ==
== Budowa jądra ==
Wyróżnia się kilka podstawowych metod konstrukcji jąder:
Wyróżnia się kilka podstawowych metod konstrukcji jąder:

Wersja z 09:31, 26 paź 2021

Jądro systemu operacyjnego (ang. kernel) – podstawowa część systemu operacyjnego, która jest odpowiedzialna za wszystkie jego zadania.

Budowa jądra

Wyróżnia się kilka podstawowych metod konstrukcji jąder:

Model funkcjonowania jądra monolitycznego.
  • jądro monolityczne – często stosowane w systemach typu Unix. Wszystkie zadania są wykonywane przez jądro, będące jednym, dużym programem działającym w trybie jądra. Przykładami takiego jądra mogą być: Linux, OpenBSD, FreeBSD, chociaż większość posiada umiejętność dołączania i odłączania modułów (najczęściej zawierających kod sterownika urządzenia lub obsługi potrzebnego w danej chwili systemu plików). Zaletą tej techniki jest prostota, stabilność, łatwość komunikacji pomiędzy różnymi członami jądra (jedna przestrzeń adresowa). Wadą jest, w późniejszym stadium rozwoju projektu, uciążliwość w rozwijaniu programu oraz w znajdywaniu błędów.
Model komunikacji mikrojądra z aplikacjami.
  • mikrojądro – w tej technice z monolitycznego jądra zostaje tylko jego podstawowa część, a części odpowiedzialne za bardziej wyrafinowane funkcje są wydzielone do funkcjonalnych bloków albo realizowane jako zwykłe procesy w trybie użytkownika.
  • nanojądro – technika zbliżona do techniki mikrojądra, różnica w wielkości – nanokernel jest jeszcze mniejszy.
  • exokernel – architektura będąca odmianą nanojądra. Cechą wyróżniającą jest możliwość zarządzania zasobami systemu przez nieuprzywilejowanego użytkownika, a rola jądra sprowadza się do zabezpieczania zasobów. Przykładem systemu korzystającego z tego typu jądra jest system XOK, zbudowany w MIT Laboratory for Computer Science, pracujący na komputerach PC. Wyposażony on został w bibliotekę ExOS, która implementuje system UNIX i umożliwia uruchamianie większości aplikacji tego systemu.
  • cachekernel – w tej technice jądro systemu buforuje obiekty systemowe takie jak wątki czy przestrzenie adresowe tak jak sprzęt komputerowy buforuje pamięć. Jądra aplikacji trybu użytkownika są odpowiedzialne za ładowanie tych danych i ponowne ich zapisanie stosując specyficzne dla danej aplikacji mechanizmy.
Model komunikacji jądra hybrydowego z aplikacjami.
  • jądro hybrydowe – kompromis między architekturą jądra monolitycznego i mikrojądra. W krytycznych usługach – np. stos sieci – usługi są na stałe wkompilowane w główny kod jądra, inne usługi pozostają oddzielone od głównego jądra i działają jako serwery (w przestrzeni jądra). Dzięki temu rozwiązaniu możliwe jest zachowanie wydajności jądra monolitycznego dla kluczowych usług. Klasyfikacja ta budzi kontrowersje niektórych programistów[1].

Cechy jądra

Z budowy jądra wynikają jego cechy, takie jak:

Zastosowanie systemów operacyjnych

Zastosowanie systemów operacyjnych wynika ściśle z ich budowy, a to przeważnie sprowadza się do budowy ich jądra. Tak więc:

Przykłady jąder systemów operacyjnych

Jądra monolityczne:

Hybrydowe:

Mikrojądra:

Przypisy

  1. [1] Torvalds, L. (maj 2006). Hybrid kernel, not NT.