Uživatelské nástroje

Nástroje pro tento web


navody:vps:vpsadminos:nixops

Rozdíly

Zde můžete vidět rozdíly mezi vybranou verzí a aktuální verzí dané stránky.

Odkaz na výstup diff

Obě strany předchozí revizePředchozí verze
Následující verze
Předchozí verze
navody:vps:vpsadminos:nixops [2019/01/10 20:02] – [vpsFree fork] update nixops rmarkonavody:vps:vpsadminos:nixops [2023/07/31 19:45] (aktuální) – ponechany jen dulezite informace Aither
Řádek 1: Řádek 1:
-====== nixops ======+====== NixOps ======
  
-  * nixops manual https://nixos.org/nixops/manual/ +NixOps je nástroj pro správu [[navody:distribuce:nixos|NixOS]] systémů. Umožnuje konfigurovat 
-  * příklad deploymentu https://github.com/vpsfreecz/example-nixops-deployment/+vícero strojů (např. VPS) z jednoho místa. Více informací viz [[https://nixos.org/nixops/manual/|NixOps manuál]].
  
-Pro konfiguraci kontejnerů běžících na vpsFree je také možné použít nástroj nixops. nixops rozšiřuje možnosti deklarativní konfigurace NixOS pro deploy clusteru NixOS mašin.+===== Ukázková konfigurace =====
  
-''nixops'' je možné nainstalovat mezi systemové balíky pomocí:+  * https://github.com/vpsfreecz/example-nixops-deployment/
  
-<code> 
-  environment.systemPackages = with pkgs; [ 
-    nixops 
-  ]; 
-</code> 
- 
-nebo do uživatelského profilu pomocí ''nix-env -i nixops'' 
- 
-Je také možné nainstalovat unstable verzi použitím ''nixopsUnstable''. 
- 
-''nixops'' umožňuje použití různých backendů a jejich mixovaní. Tento návod dále obsahuje popis 
-použití ''libvirt'' backendu pro rychlý deploy do ''qemu'' pomocí ''libvirtd'' a ''none'' backendu pro deploy předem připravených VPS přes ''SSH''. 
- 
-===== Příklad ===== 
- 
-Začneme naklonováním repozitáře se vzorovým deploymentem: 
- 
-<code> 
-git clone https://github.com/vpsfreecz/example-nixops-deployment/ 
-</code> 
- 
-Deployment v ''network.nix'' definuje dva stroje s názvy ''hello'' a ''world'', které použivají ''include'' pro import konfigurace z adresáře ''machines''. Konfigurace ''machines/hello.nix'' ukazuje nasazení webservru ''nginx'' a konfigurace ''machines/world.nix'' zapnutí ''PostgreSQL''. 
- 
-==== libvirt backend ==== 
- 
-Vzorový deployment je možné otestovat pomocí ''libvirt'' backendu. Pomocí ''nixops create'' vyvoříme nový deployment s názvem ''virt'', který se bude skládat z ''network.nix'' (logická konfigurace) a ''network-libvirt.nix'' (fyzická konfigurace, specifická pro ''libvirt''). 
- 
-Takto vytvořený deployment můžeme nasadit pomocí příkazu ''deploy''. Deploy v případě ''libvirt'' backendu vyrobí definované virtuální stroje a nahraje na ně novou konfiguraci. 
- 
-V připadě, že nespecifikujeme proměnnou prostředí ''NIXOPS_DEPLOYMENT'', je potřeba použít parametr ''-d'' a určit název deploymentu. 
- 
-<code bash> 
-nixops create -d virt network.nix network-libvirt.nix 
-nixops deploy -d virt 
-</code> 
- 
-Nyní zbýva zjistit IP adresu stroje ''hello'' pomocí 
-<code bash> 
-nixops info -d virt 
-</code> 
- 
-a otestovat nově nahozený webserver pomocí ''curl IP''. 
- 
-Deployment je možné měnit a znovu re-deploynout pomocí ''nixops deploy''. 
- 
-==== none backend ==== 
- 
-Pro deploy fyzických strojů nebo kontejnerů je možné použít ''none'' backend, který žádné stroje nevytváří, ale používá SSH k nahrání nové konfigurace. Obdobně ako pro virtualizovaný deployment, vytvoříme nový deployment s názvem ''none'', který bude jako fyzickou část konfigurace používat ''network-none.nix''. 
- 
-Před samotným ''deploy'' je potřebné vytvořit cílove stroje (VPSky) a změnit IP adresy v ''network-none.nix''. 
- 
-<note> 
-None backend při prvním spuštění ''deploy'' vygeneruje nový pár SSH klíčů a zeptá se na heslo ke stroji/VPS - přikaz ''deploy'' byl proto doplněn o ''--include hello'' aby nejdřív došlo k instalaci prvního stroje. Pokud deploy pustíme bez parametru, SSH sa zeptá na heslo ke všem strojím najednou a dojde k zahlcení konzole - pro tento případ je lepší použít "dumb" backend pospaný v nasledujíci sekci. 
-</note> 
- 
-<code bash> 
-nixops create -d none network.nix network-none.nix 
-nixops deploy -d none --include hello 
-</code> 
- 
-==== dumb backend ==== 
- 
-''dumb'' podobně jako ''none'' backend funguje po SSH, ale nevytváří páry klíčů pro stroje. Místo toho používá standardní konfiguraci SSH přes ''~/.ssh/config'' kde je možné vybrat správný SSH klíč pro použití pro deploy. V případě nastavených SSH klíčů ve ''vpsAdminu'' tak není nutné sahat před samotným deploy na cílovy stroj. 
- 
-<note> 
-Dumb backend je dostupný ve [[navody:vps:vpsadminos:nixops#vpsfree_fork|vpsFree forku nixops]] 
-</note> 
- 
-<code bash> 
-nixops create -d dumb network.nix network-dumb.nix 
-nixops deploy -d dumb 
-</code> 
- 
-===== FAQ ===== 
- 
-<code bash> 
-- preco musim opakovat -d /o\ 
-- pinning (see activation) 
-- ruzne verze nixpkgs 
-- ct.nix 
-</code> 
  
 ===== Uživatelské konfigurace ===== ===== Uživatelské konfigurace =====
  
-  * https://github.com/vpsfreecz/vpsfree-cz-configuration 
-  * https://gitea.havefun.cz/aither/havefun-cz-configuration/ 
-  * https://github.com/sorki/48-io-configuration/ 
   * https://github.com/otevrenamesta/otevrenamesta-cz-configuration   * https://github.com/otevrenamesta/otevrenamesta-cz-configuration
-  * https://github.com/kriloter/nixos/ 
- 
-===== vpsFree fork ===== 
- 
-Pro instalaci stačí uložit následující config do ''/etc/nixos'' například pod názvem ''vpsfreeNixops.nix'' 
-a použít ''import ./vpsfreeNixops.nix''. 
- 
-<code> 
-{ config, lib, pkgs, ... }: 
-let 
-  nixopsRepo = pkgs.fetchFromGitHub { 
-    owner = "vpsfreecz"; 
-    repo = "nixops"; 
-    rev = "d8f4f251625c812d557a121db24481d0f2fe1882"; 
-    sha256 = "1assx4w42nvwyyk7b80730ywr5w87ldyi7zyzg7x4y0y6cva4jig"; 
-  }; 
-in 
-{ 
-  nixpkgs.overlays = [ 
-    (self: super: 
-      { 
-        nixops = (import "${nixopsRepo}/release.nix" {}).build.x86_64-linux; 
-      } 
-    ) 
-  ]; 
- 
-  environment.systemPackages = with pkgs; [ 
-    screen 
-    nixops 
-    git 
-  ]; 
-} 
-</code> 
- 
- 
-===== vpsFree fork (libvirt verze) ===== 
- 
-Tato verze je určena pro běh nixops v kontejneru, ve kterém zároveň běží ''libvirt''. ''libvirt'' je nutno nakonfigurovat se statickou síti a vlastním bridge + DHCP, se kterým nefunguje oficiální verze ''nixops''. Tato verze přidává podporu pro ''qemu-agent'' a zjišťuje IP z bežícího virtuálního stroje. 
- 
-Příklad konfigurace ''libvirt'': 
-  * modul (libvirt + DHCP + NAT) https://github.com/sorki/48-io-configuration/blob/master/modules/libvirt.nix 
-  * konfigurace (nixops overlay) https://github.com/sorki/48-io-configuration/blob/master/machines/lvirt.nix 
- 
-<note> 
-Pro správné fungování ''libvirtd'' je potřebné pro VPS zapnout KVM a TUN features. 
-</note> 
- 
-Pro instalaci stačí uložit následující config do ''/etc/nixos'', například pod názvem ''vpsfreeNixops.nix'' 
-a použít ''import ./vpsfreeNixops.nix''. 
- 
-<code> 
-{ config, lib, pkgs, ... }: 
-let 
-  nixopsRepo = pkgs.fetchFromGitHub { 
-    owner = "vpsfreecz"; 
-    repo = "nixops"; 
-    rev = "668a0f9de10c04dbb7df8c1e4f2be7b064834432"; 
-    sha256 = "05ahx1snrddb715r1pdbjk1ywfqa829c6wys9icawxygh2ngspki"; 
-  }; 
-in 
-{ 
-  nixpkgs.overlays = [ 
-    (self: super: 
-      { 
-        nixops = (import "${nixopsRepo}/release.nix" {}).build.x86_64-linux; 
-      } 
-    ) 
-  ]; 
- 
-  environment.systemPackages = with pkgs; [ 
-    screen 
-    nixops 
-    git 
-  ]; 
-} 
-</code> 
  
navody/vps/vpsadminos/nixops.1547150571.txt.gz · Poslední úprava: 2019/01/10 20:02 autor: rmarko