Please note that, for the purpose of this project, conforming to 'pythonic' way was not a goal as in future, implementation might change to Rust, C, C++, etc. We would like to be as close to POSIX-compliant sans-bashism shell as possible.
- Co je astOS?
- astOS ve srovnání s jinými podobnými distribucemi
- dokumentace k ast a astOS
- Další dokumentace
- Známé chyby
- Přispívání
astOS je moderní distribuce založená na Arch Linuxu. Na rozdíl od Archu používá neměnný (pouze pro čtení) kořenový souborový systém. Software je instalován a konfigurován do jednotlivých stromů snímků, které lze následně nasadit a zavést do systému. Nepoužívá vlastní formát balíčků ani správce balíčků, místo toho se spoléhá na pacman z Archu.
To má několik výhod:
-
Bezpečnost
- I když je aplikace spuštěna s vyvýšenímy právy, nemůže nahradit systémové knihovny škodlivými verzemi.
-
Stabilita a spolehlivost
- Díky tomu, že je systém připojen pouze pro čtení, není možné omylem přepsat systémové soubory.
- Pokud se systém dostane do problémů, můžete během několika minut snadno vrátit poslední funkční snímek.
- Atomické aktualizace - aktualizace systému najednou je spolehlivější.
- Díky funkci snapshotu může systém astOS dodávat špičkový software, aniž by se stal nestabilním
- astOS nepotřebuje téměř žádnou údržbu, protože má vestavěný plně automatický aktualizační nástroj, který před aktualizacemi vytváří snapshoty a před nasazením nového snapshotu automaticky kontroluje, zda se systém správně aktualizoval
-
Konfigurovatelnost
- Díky snapshotům uspořádaným do stromu můžete mít snadno k dispozici více různých konfigurací softwaru s různými balíčky, aniž by došlo k jakémukoli zásahu do systému
- Například: můžete mít nainstalovanou jednu pracovní plochu Gnome a nad ní mít dva překryvy - jeden s videohrami, s nejnovějším jádrem a ovladači, a druhý pro práci, s jádrem LTS a stabilnějším softwarem, mezi nimiž pak můžete snadno přepínat podle toho, co se snažíte dělat.
- Můžete také snadno zkoušet software, aniž byste se museli obávat, že si rozbijete systém nebo ho znečistíte nepotřebnými soubory, například můžete vyzkoušet nové desktopové prostředí ve snapshotu a poté snapshot smazat, aniž byste vůbec měnili svůj hlavní systém.
- To lze využít i pro víceuživatelské systémy, kde má každý uživatel zcela samostatný systém s jiným softwarem, a přesto může sdílet určité balíčky, například jádra a ovladače.
- astOS umožňuje instalovat software pomocí chrootování do snapshotů, proto můžete k instalaci dalších balíčků použít software, jako je AUR.
- astOS je stejně jako Arch velmi přizpůsobitelný, můžete si přesně vybrat software, který chcete používat.
-
Díky své spolehlivosti a automatickým aktualizacím je astOS vhodný pro jednorázová nebo vestavěná zařízení.
-
Je také dobrou distribucí pro pracovní stanice nebo obecné použití s využitím vývojových kontejnerů a flatpaku pro desktopové aplikace.
- NixOS - ve srovnání s nixOS je astOS tradičnější systém, co se týče nastavení a údržby. Zatímco nixOS je kompletně konfigurován pomocí programovacího jazyka Nix, astOS používá správce balíčků Arch pacman. astOS používá snímky btrfs.
- astOS umožňuje deklarativní konfiguraci pomocí Ansible, pro podobnou funkčnost jako NixOS.
- Fedora Silverblue - astOS je lépe přizpůsobitelný, ale vyžaduje více ručního nastavení.
- OpenSUSE MicroOS - astOS je více přizpůsobitelný systém, ale opět vyžaduje trochu více ručního nastavení. MicroOS funguje podobně jako astOS ve způsobu, jakým využívá snímky btrfs.
- astOS se instaluje z oficiálního Live iso Arch Linuxu dostupného na https://archlinux.org/.
Nejprve nainstalujte git - to nám umožní stáhnout instalační skript.
pacman -Sy git
Klonování repozitáře
git clone "https://github.com/astos/astos"
cd astOS
Rozdělení a formátování disku
lsblk # Zjistěte název jednotky
cfdisk /dev/*** # naformátujte disk, nezapomeňte přidat oddíl EFI, pokud používáte BIOS, nechte před oddílem 2M pro bootloader
Spusťte instalační program
python3 main.py /dev/<oddíl> /dev/<disk> /dev/<efi oddíl> # V případě instalace v režimu BIOS můžete oddíl EFI vynechat.
- astOS neprovádí mnoho nastavení pro uživatele, proto bude nutné provést nějaké nastavení po instalaci.
- Mnoho informací o tom, jak zvládnout poinstalační nastavení, je k dispozici na stránce ArchWiki.
- Zde je malý příklad postupu nastavení:
- Začněte vytvořením nového snímku ze základního obrazu pomocí
ast clone 0
) - Uvnitř tohoto nového snapshotu proveďte chroot (
ast chroot <snapshot>
) a začněte s nastavováním.- Začněte přidáním nového uživatelského účtu:
useradd username
- Nastavte uživatelské heslo
passwd username
- Nyní nastavte nové heslo pro uživatele root
passwd root
- Nyní můžete pomocí programu pacman nainstalovat další balíčky (desktopová prostředí, kontejnerové technologie, flatpak).
- Po dokončení ukončete chroot pomocí
exit
- Poté jej můžete nasadit pomocí
ast deploy <snapshot>
- Začněte přidáním nového uživatelského účtu:
- Začněte vytvořením nového snímku ze základního obrazu pomocí
- Doporučujeme podívat se na Arch wiki, kde najdete dokumentaci, která není součástí tohoto projektu.
- Nahlášení problémů/chyb na Github issues page.
- Snímek
0
je vyhrazen pro základní obraz systému, nelze jej měnit a lze jej aktualizovat pouze pomocíast base-update
.
ast strom
- Výstup může vypadat například takto:
root - kořen
├── 0 - základní obraz
└── 1 - víceuživatelský systém
└── 4 - aplikace
├── 6 - plná pracovní plocha MATE
└── 2*- plná pracovní plocha Plasma
-
Hvězdička ukazuje, který snímek je aktuálně zvolen jako výchozí
-
Můžete také získat pouze číslo aktuálně spuštěného snapshotu pomocí příkazu
ast current
- Snímky umožňují přidat k nim popis pro snadnější identifikaci.
ast desc <snímek> <popis>
- Odstraní strom a všechny jeho větve.
ast del <strom>
- Pokud potřebujete použít vlastní konfiguraci grubu, chrootněte se do snapshotu a upravte
/etc/default/grub
, poté snapshot nasaďte a restartujte počítač.
- Po vstupu do chrootu se operační systém chová jako běžný Arch, takže můžete instalovat a odebírat balíčky pomocí pacmanu nebo podobného nástroje.
- Nespouštějte ast zevnitř chrootu, mohlo by dojít k poškození systému, je zde pojistka proti selhání, kterou lze obejít pomocí
--chroot
, pokud to opravdu potřebujete (nedoporučuje se).
ast chroot <snapshot>
- Spustí příkaz ve snapshotu
ast run <snapshot> <příkaz>
- Spustí příkaz ve snapshotu a všech jeho podvětvích
ast tree-run <strom> <příkaz>
- Klonuje snapshot jako nový strom.
ast clone <snapshot>
- Přidá novou větev k zadanému snímku.
ast branch <snapshot, z něhož se má větev vytvořit>
ast cbranch <snapshot>
- Nezapomeňte po této funkci synchronizovat strom
- Rodič je větev pod kterou chcete klonovat
ast ubranch <rodič> <snapshot>
ast new
- Po nasazení restartujte systém, abyste nabootovali do nového snapshotu.
ast deploy <snapshot>
ast base-update
- Poznámka: samotná báze je umístěna na
/.snapshots/snapshot-0
, přičemž její specifické soubory/var
a/etc
jsou umístěny na/.var/var-0
a/.etc/etc-0
, proto pokud opravdu potřebujete provést změnu konfigurace, můžete tyto snapshoty připojit jako read-write a poté snapshoty zpět jako read only
- Po instalaci nového softwaru spusťte
ast deploy <snapshot>
a restartujte počítač, aby se změny uplatnily. - Software lze také nainstalovat pomocí pacmanu do chrootu
- Pod chrootem lze použít AUR
- Pro trvalou instalaci balíčků lze použít Flatpak
- Použití kontejnerů pro instalaci dalšího softwaru je také možností, výhodou je, že není třeba restartovat počítač. Doporučeným způsobem je použití distrobox.
ast install <snapshot> <balíček>
- Po instalaci můžete synchronizovat nově nainstalované balíčky do všech větví stromu pomocí příkazu
ast sync <strom>
- Pro jediný snapshot
ast remove <snapshot> <balíček či balíčky>
- Rekurzivně
ast tree-rmpkg <strom> <balíček či balíčky>
-
Před aktualizací se doporučuje klonovat snímek, abyste se mohli v případě selhání vrátit zpět.
-
Aktualizace jednoho snímku
ast upgrade <snapshot>
- Pro rekurzivní aktualizaci celého stromu
ast tree-update <strom>
- Tuto funkci lze nakonfigurovat ve skriptu (tj. ve skriptu crontab) pro snadné a bezpečné automatické aktualizace.
- Při spuštění ast bez argumentů - IndexError: index seznamu mimo rozsah
- Při spuštění ast bez práv roota se místo chybové zprávy zobrazí chyba s odepřenými právy.
- GDM a LightDM nemusí fungovat
- Při zapnutí a vypnutí systému "Error: failed to remount root and boot filesystems"
- Nefunuguje swap oddíl, je doporučeno použít swapfile nebo zram
- Docker má problémy s oprávněními, pro opravu spusťte
sudo chmod 666 /var/run/docker.sock
- Pokud narazíte na nějaké problémy, nahlaste je na stránce problémů.
- Příspěvky do kódu a dokumentace jsou vítány
- Dobrým způsobem, jak přispět k projektu, je také hlášení chyb.
- Před odesláním pull requestu kód otestujte a ujistěte se, že je řádně okomentován.
Projekt je licencován pod licencí AGPLv3