💾 Archived View for gronkiewicz.dev › zmiana-na-nixos captured on 2024-09-29 at 00:30:17. Gemini links have been rewritten to link to archived content
-=-=-=-=-=-=-
2021-08-24 Patryk Gronkiewicz
Ostatnio zmieniłem system na NixOS po odrobinie zabawy z konfiguracją w maszynie wirtualnej. Jest to bardzo ciekawe rozwiązanie, przyjemnie się z niego korzysta, jednak na samym początku wcale nie jest łatwo. Najtrudniejszą częścią jest fakt, że na oficjalnej wiki projektu nie znajdziemy wielu pomocnych informacji, ale jest kilka dobrych źródeł, takich jak nieoficjalna wiki[0], a także nix.dev[1]. Oba te źródłą są swietne, jednak nadal - bardzo dużo informacji najłatwiej znaleźć w ramach wątków na Reddicie, StackOverflow czy mało znanych blogach.
Pierwsze i najważniejsze - czym w zasadzie różni się Nix od NixOS? Odpowiedź jest bardzo prosta, choć nie do końca oczywista. Nix jest językiem czysto funkcyjnym (zupełnie jak Haskell), który służy do deklarowania konfiguracji i paczek. NixOS jest natomiast systemem, którego bazą jest Nix. Nie trzeba używać NixOSa, żeby używać Nixa - sam nix jest dostępny na (chyba) dowolną dystrybucję Linuxa, a także na mac OS jako alternatywa Homebrew.
Instalacja NixOS to jedna z najprostszych rzeczy - `configuration.nix` napisałem jeszcze podczas nauki w maszynie wirtualnej, trzeba było dopisać jedynie kilka linijek w temacie Wi-Fi. Uruchomiłem także podmana i backupy przez restic. Było to łatwiejsze niż na większości dystrybucji Linuxa ze względu na ujednolicony interfejs. Jedyną ciężką rzeczą było zrozumienie Nixa, ponieważ wcześniej praktycznie nie miałem kontaktu z czysto funkcyjnymi językami.
Użytkowanie NixOS na codzień jest zaskakująco proste - jedynym problemem jest kompilacja niektórych paczek, jednak wcześniejsze doświadczenia z Archem mnie trochę zahartowały. Jedyne paczki, jakie czasem wymagają kompilacji w moim zestawie to:
- Emacs - używam wersji kompilowanej natywnie, przez co sam edytor działa dużo szybciej
- MultiMC - ze względu na problemy licencyjne (nie wnikałem za bardzo jakie dokładnie) - opiekunowie paczki w repozytorium postanowili usunąć cache, pozostawiając jednak paczkę.
Czasami zdarza się, że jakiejś aplikacji nie ma lub nie działa tak, jak spodziewalibyśmy się tego, jednak w większości przypadków nie jest to bardzo duży problem.
Najciekawszą częścią mojej codziennej pracy jest pisanie kodu (głównie w pythonie) - tutaj na samym początku pojawiło się kilka zgrzytów ze względu na niestandardowość NixOSa - `pip`? Nie działa. `conda`? Nie działa. `poetry`? Zgadnijcie co! Nie działa. Rozwiązaniem okazał się MachNix[2]. Pozwolił mi on na przygotowanie uniwersalnego pliku, który wrzucam do każdego repozytorium i gotowe! Na dodatek zacząłem korzystać z direnv[3] i lorri[4], które automatycznie ładują moje środowisko i doinstalowują paczki lokalnie, jeśli tylko `requirements.txt` lub `shell.nix` zmieni się. Dla przykładu poniżej zamieszczam swój `shell.nix`, który raczej się z projektu na projekt nie zmienia.
let mach-nix = import (builtins.fetchGit { url = "https://github.com/DavHau/mach-nix/"; ref = "master"; }) { python = "python38"; }; in mach-nix.mkPythonShell { providers._default = "conda,wheel,nixpkgs,sdist"; requirements = builtins.readFile ./requirements.txt; }
<div class="src-block-caption">
<span class="src-block-number">Kod 1</span>:
It ain't much, but at least it's honest
</div>
Nie jest to może nic nadzwyczajnego, jednak chwilę zajęło mi dojście do odpowiedniego wyglądu tego pliku, aby był stosunkowo uniwersalny (z jakiegoś powodu kopia 1:1 z dokumentacji nie dawała u mnie odpowiedniego efektu). Między projektami w zasadzie zmienia się tylko kolejność providerów oraz wersja Pythona.
W tym momencie korzystam ze "stabilnej" wersji paczek, jednak przyszłość jest w Nix Flakes. Nie do końca jeszcze rozumiem ich działanie, jednak powoli przepisuję swoją konfigurację właśnie na nie. Pozwoli to na zachowanie deklaratywności systemu. Dodatkowym planem jest umieszczenie ich wszystkich w ramach pliku `README.org` w repozytorium, dzięki czemu całość konfiguracji będzie mogła zostać udokumentowana razem z odpowiednim formatowaniem. Coraz więcej osób korzysta z Flake'ów, ponieważ dają dużo większą kontrolę nad wersjami, dużo łatwiej jest zablokować wersję **co do commita** w repozytorium.
Po korzystaniu z NixOS od mniej więcej 2 miesięcy mogę zdecydowanie stwierdzić, że jest to system ciekawy, który ma na pewno bardzo duży potencjał, na co wskazuje też coraz szybciej rosnąca społeczność wokół niego. Dzięki niemu mogłem poznać zupełnie nowe koncepty, osoby na Reddicie (r/NixOS[5]), mogłem zaznajomić się lepiej z programowaniem funkcyjnym, a także uświadczyłem tego, że nie muszę pisać skryptu, który wszystko ustawia, a mieć gotowy system tuż po instalacji, bez dodatkowych skryptów. Na dodatek zauważyłem, że konfiguracja mojego serwera i laptopa wcale aż tak bardzo się nie różnią między sobą, więc bardzo prosto jest je połączyć i ustawić w taki sposób, aby ładowała się dodatkowa konfiguracja w zależności od maszyny. Kto wie, może następnym krokiem będzie usunięcie moich ulubieńców[6]? Zobaczymy, co jeszcze nadejdzie, jednak mam wrażenie, że NixOS zostanie ze mną na dłużej, może nawet dłużej niż Arch Linux czy _Pop_!_OS.