NixOS - NixOS
Tento článek má několik problémů. Prosím pomozte vylepši to nebo diskutovat o těchto otázkách na internetu diskusní stránka. (Zjistěte, jak a kdy tyto zprávy ze šablony odebrat) (Zjistěte, jak a kdy odstranit tuto zprávu šablony)
|
Napsáno | Nix výrazový jazyk |
---|---|
Rodina OS | Unixový |
Pracovní stav | Ve vývoji |
Zdrojový model | Otevřený zdroj |
První vydání | 2003 |
Poslední vydání | 20.09 / 27 října 2020[1] |
Úložiště | |
Marketingový cíl | Obecný účel |
Správce balíčků | Nix |
Platformy | i686, x86-64, ARMv7, AArch64 |
Jádro typ | Monolitické (Linuxové jádro ) |
Licence | MIT[2] |
Oficiální webové stránky | nixos |
NixOS je Linuxová distribuce postavený na vrcholu Správce balíků Nix. Využívá to deklarativní konfigurace a umožňuje spolehlivé upgrady systému.[3] Jsou nabízeny dvě hlavní větve: aktuální stabilní verze a nestabilní po nejnovějším vývoji. Ačkoli NixOS začínal jako výzkumný projekt,[4] je to plně funkční a použitelný operační systém.[Citace je zapotřebí ] NixOS má nástroje určené pro DevOps a úlohy nasazení.[5][6]
Dějiny
NixOS začal jako výzkumný projekt Eelco Dolstra v roce 2003.[4][7]
The Stichting NixOS byl založen v roce 2015 a jeho cílem je podporovat projekty jako NixOS, které implementují čistě funkční model nasazení.[8]
Verze
NixOS následuje kadencované vydání, dvakrát ročně[9], obvykle v březnu a v září. Každé číslo verze má následující formát: „YY.MM“.
Například: „20.03“ je verze vydaná kolem března 2020.
Kromě toho je každá verze pojmenována, například „Markhor“ pro vydání 20.03.
Historie verzí | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Funkce
Deklarativní model konfigurace systému
V NixOS je celý operační systém - jádro, aplikace, systémové balíčky, konfigurační soubory, a tak dále - je vytvořen správcem balíků Nix z popisu ve funkčním sestavovacím jazyce. To znamená, že vytváření nové konfigurace nemůže přepsat předchozí konfigurace.[11]
Systém NixOS se konfiguruje zapsáním specifikace funkce, kterou chce uživatel na svém počítači, do globálního konfiguračního souboru. Zde je například minimální konfigurace počítače, na kterém je spuštěn démon SSH:[12]
{ boot.nakladač.grub.zařízení = „/ dev / sda“; fileSystems."/".zařízení = „/ dev / sda1“; služby.sshd.povolit = skutečný;}
Po změně konfiguračního souboru lze systém aktualizovat pomocí přepínač nixos-rebuild
příkaz. Tento příkaz provede vše potřebné k použití nové konfigurace, včetně stahování a kompilace balíčků a generování konfiguračních souborů.
Spolehlivé upgrady
Protože soubory Nix jsou čistý a deklarativní jejich vyhodnocení vždy vyprodukuje stejný výsledek bez ohledu na to, jaké balíčky nebo konfigurační soubory jsou v systému. Aktualizace systému je tedy stejně spolehlivá jako nová instalace od nuly.
Atomové upgrady
NixOS má transakční přístup ke správě konfigurace, který provádí změny konfigurace, například upgrady atomový. To znamená, že pokud dojde k přerušení upgradu na novou konfiguraci - řekněme, že napájení v polovině selže - bude systém stále v konzistentním stavu: bude spuštěn ve staré nebo nové konfiguraci. V jiných systémech může stroj skončit v nekonzistentním stavu a už se nemusí ani spustit.[13]
Vrácení zpět
Pokud je po aktualizaci systému nová konfigurace nežádoucí, lze ji vrátit pomocí speciálního příkazu (nixos-rebuild switch --rollback
). Každá verze konfigurace systému se automaticky zobrazí v nabídce spuštění systému. Pokud nová konfigurace selže nebo se nespustí správně, lze vybrat starší verzi. Vrácení zpět jsou lehké operace, které nezahrnují soubory obnovované z kopií.
Reprodukovatelné konfigurace systému
Deklarativní konfigurační model NixOS usnadňuje reprodukci konfigurace systému na jiném počítači. Zkopírováním konfiguračního souboru do cílového počítače a spuštěním příkazu aktualizace systému se vygeneruje stejná konfigurace systému (jádro, aplikace, systémové služby atd.) S výjimkou částí systému, které nespravuje správce balíčků, například uživatelských dat.
Zdrojový model s binárními soubory
Jazyk sestavení Nix používaný systémem NixOS určuje, jak vytvářet balíčky ze zdroje. To usnadňuje přizpůsobení systému potřebám uživatelů. Avšak při vytváření ze zdroje, který je pomalý proces, správce balíčků automaticky stáhne předem připravené binární soubory ze serveru mezipaměti, pokud jsou k dispozici. To dává flexibilitu modelu správy balíčků založeného na zdroji s účinností binárního modelu.[14]
Konzistence
Správce balíků Nix zajišťuje, že běžící systém je v souladu s logickou specifikací systému, což znamená, že znovu sestaví všechny balíčky, které je třeba znovu sestavit. Například pokud dojde ke změně jádra, správce balíčků zajistí, že budou znovu sestaveny externí moduly jádra. Podobně při aktualizaci knihovny zajišťuje, že všechny systémové balíčky používají novou verzi, dokonce i balíčky, které jsou k ní staticky připojeny.
Správa víceuživatelských balíčků
K instalaci softwaru v systému NixOS není potřeba žádná speciální oprávnění. Kromě celosystémového profilu má každý uživatel vyhrazený profil, do kterého může instalovat balíčky. Nix také umožňuje koexistovat více verzí balíčku, takže různí uživatelé mohou mít ve svých příslušných profilech nainstalovány různé verze stejného balíčku. Pokud si dva uživatelé nainstalují stejnou verzi balíčku, bude vytvořena nebo stažena pouze jedna kopie a model zabezpečení Nix zajistí, že je zabezpečená.
Implementace
NixOS je založen na správci balíků Nix, který ukládá všechny balíčky odděleně od sebe v úložišti balíků.
Instalované balíčky jsou identifikovány kryptografickým hashem veškerého vstupu použitého pro jejich sestavení. Změna pokynů k sestavení balíčku upraví jeho hodnotu hash, což povede k instalaci jiného balíčku v úložišti balíků. Tento systém se také používá ke správě konfiguračních souborů zajišťujících, že novější konfigurace nepřepisují starší.
Důsledkem toho je, že NixOS nedodržuje Standard hierarchie souborového systému. Jedinou výjimkou je symbolický odkaz / bin / sh na verzi bash v obchodě Nix (například: /nix/store/s/5rnfzla9kcx4mj5zdc7nlnv8na1najvg-bash-4.3.43/
); a zatímco NixOS má /atd adresář pro uchování konfiguračních souborů v celém systému, většina souborů v tomto adresáři má symbolické odkazy na vygenerované soubory / nix / obchod jako / nix / store / s2sjbl85xnrc18rl4fhn56irkxqxyk4p-sshd_config
. Nepoužívání globálních adresářů, jako je /zásobník je součástí toho, co umožňuje koexistenci více verzí balíčku.
Recepce
Jesse Smith zkontroloval NixOS 15.09 pro DistroWatch Weekly.[15] Smith napsal:
Velmi se mi líbí způsob, jakým si NixOS dělá starosti s upgradováním balíků tím, že každou změnu umístí do své vlastní „generace“, a zjistil jsem, že z pohledu koncového uživatele NixOS funguje stejně jako jakákoli jiná distribuce Linuxu. Nastavení NixOS není pro začátečníky a nemyslím si, že by měl být NixOS používán jako desktopový operační systém pro všeobecné použití. Ale to, co NixOS dělá, je to, že nám poskytne užitečné hřiště, na kterém budeme zkoumat správce balíčků Nix, a myslím, že je to velmi zajímavá technologie, která si zaslouží další zkoumání a přijetí dalšími distribucemi.
DistroWatch Weekly má také recenzi na NixOS 17.03, kterou napsal Ivan Sanders.[16]
Viz také
- Správce balíků Nix - Správce balíků, na kterém je založen NixOS
- Systém GNU Guix - Operační systém postavený na GNU Guix která je inspirována Nixem[17]
Reference
- ^ „Vydání 20.09 („ Slavík “, 2020-10-27)“. 2020-10-27. Citováno 2020-10-28.
- ^ „nixpkgs / KOPÍROVÁNÍ na master · NixOS / nixpkgs · GitHub“. Github.com. Citováno 2015-09-19.
- ^ „DistroWatch.com: NixOS“. Distrowatch.com. Citováno 2015-09-19.
- ^ A b Dolstra, Eelco. „Integrace konstrukce softwaru a nasazení softwaru“ (PDF). Přednášky z informatiky. 2649: 102–117. Archivovány od originál (PDF) dne 2019-04-21.
- ^ „NixOps - NixOS Cloud Deployment Tool“. Nixos.org. Citováno 2015-09-19.
- ^ „Disnix“. Nixos.org. Citováno 2015-09-19.
- ^ Dolstra, Eelco (2006). Čistě funkční model nasazení softwaru (PDF) (Ph.D.). Archivovány od originál (PDF) dne 09.06.2019.
- ^ „Stichting NixOS Foundation“. Nixos.org. Citováno 2015-09-19.
- ^ „Správa“. Nixos.org. Citováno 2020-08-28.
- ^ „Dodatek B. Poznámky k verzi“. Nixos.org. Citováno 2020-08-28.
- ^ Dolstra, Eelco; Hemel, Armijn (2007). „Čistě funkční správa konfigurace systému“ (PDF). Archivovány od originál (PDF) dne 06.07.2019. Citovat deník vyžaduje
| deník =
(Pomoc) - ^ „About NixOS“. Nixos.org. Citováno 2015-09-19.
- ^ van der Burg, Sander; Dolstra, Eelco; de Jonge, Merijn (2008). „Atomová inovace distribuovaných systémů“ (PDF). Archivovány od originál (PDF) dne 2019-01-15. Citovat deník vyžaduje
| deník =
(Pomoc) - ^ Dolstra, Eelco (2005). „Bezpečné sdílení mezi nedůvěryhodnými uživateli v transparentním zdrojovém / binárním modelu nasazení“ (PDF). Archivovány od originál (PDF) dne 26. 9. 2019. Citovat deník vyžaduje
| deník =
(Pomoc) - ^ DistroWatch Weekly, číslo 637, 23. listopadu 2015
- ^ DistroWatch Weekly, číslo 712, 15. května 2017
- ^ „About - GuixSD“. www.gnu.org. Citováno 2018-05-03.