Développement NixOS et Nix Flakes

VérifiéSûr

Maîtrisez NixOS avec les flakes Nix pour des architectures multi-repo, déploiements isolés et infrastructure K3s déclarative. Couvre la syntaxe Nix, les modules NixOS, les dérivations et l'empaquetage OCI.

Spar Skills Guide Bot
DevOpsAvancé
3002/06/2026
Claude CodeCursorWindsurf
#nixos#nix-flakes#multi-repo#airgapped-deployment#declarative-infrastructure

Recommandé pour

Notre avis

Fournit des conseils sur la construction de configurations NixOS à l'aide de flocons Nix, en mettant l'accent sur la composition multi-dépôts, les déploiements en réseau isolé et l'infrastructure déclarative.

Points forts

  • Couverture complète de la composition multi-dépôts avec épinglage des entrées et partage de modules.
  • Exemples concrets pour l'empaquetage d'images OCI et le rendu Helm/Kustomize.
  • Conseils de dépannage pour les erreurs Nix courantes.
  • Explication des motifs de modules NixOS et de la configuration conditionnelle.

Limites

  • Nécessite des connaissances préalables du langage Nix et des bases de NixOS.
  • Ne couvre pas l'installation ou la configuration initiale de Nix.
  • Suppose une structure de flocon spécifique qui peut ne pas convenir à tous les projets.
Quand l'utiliser

Utilisez-le lors du développement de configurations NixOS avec des flocons, en particulier pour les configurations multi-dépôts ou les environnements isolés.

Quand l'éviter

Ne convient pas aux configurations mono-machine simples ou aux débutants ne connaissant pas Nix.

Analyse de sécurité

Sûr
Score qualité88/100

The skill provides reference documentation for NixOS and flake development. It does not instruct the AI to execute destructive commands, exfiltrate data, or perform unsafe actions. Mentioned commands like 'sudo nixos-rebuild switch' are standard for NixOS administration and not automatically executed. No obfuscated payloads or safety bypasses are present.

Aucun point d'attention détecté

Exemples

Set up a multi-repo NixOS flake
Create a flake.nix that pulls in two external flake repositories for NixOS modules and a development shell, pinning them to the same nixpkgs version.
Package an OCI image for airgapped deployment
Write a Nix derivation that downloads a Docker image using skopeo and outputs an OCI tarball suitable for airgapped systems.
Troubleshoot a Nix build error
I'm getting 'error: getting status of ... No such file or directory' when rebuilding my NixOS system. What are the common causes and fixes?

name: nixos description: NixOS and Nix flake development for multi-repo architectures, airgapped deployments, and K3s infrastructure. Use when working with flake.nix files, NixOS modules, derivations, devShells, overlays, OCI image packaging, or composing multiple flake repositories. Covers Nix language syntax, flake inputs/outputs, nixosModules exports, stdenv.mkDerivation, and home-manager integration.

NixOS Development

Overview

Build and maintain NixOS configurations using Nix flakes. Focus on multi-repo composition, airgapped deployments, and declarative infrastructure.

Quick Reference

| Task | Command | |------|---------| | Build package | nix build .#packageName | | Enter devShell | nix develop | | Update flake inputs | nix flake update | | Update single input | nix flake lock --update-input nixpkgs | | Show flake outputs | nix flake show | | Check flake | nix flake check | | Rebuild NixOS | sudo nixos-rebuild switch --flake .#hostname | | Build ISO | nix build .#nixosConfigurations.iso.config.system.build.isoImage |

Flake Structure

Standard multi-repo flake pattern:

{
  inputs = {
    nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";

    # Pin dependent flakes to same nixpkgs
    other-flake.url = "git+ssh://gitlab.example.com/repo";
    other-flake.inputs.nixpkgs.follows = "nixpkgs";
  };

  outputs = { self, nixpkgs, other-flake, ... }:
    let
      system = "x86_64-linux";
      pkgs = import nixpkgs { inherit system; };
    in {
      # NixOS system configurations
      nixosConfigurations.hostname = nixpkgs.lib.nixosSystem {
        inherit system;
        modules = [
          other-flake.nixosModules.default
          ./configuration.nix
        ];
      };

      # Reusable NixOS modules
      nixosModules.default = import ./modules;

      # Packages
      packages.${system} = { /* ... */ };

      # Development shells
      devShells.${system}.default = pkgs.mkShell { /* ... */ };
    };
}

NixOS Module Pattern

Export modules for composition:

# modules/default.nix
{ config, lib, pkgs, ... }:
{
  imports = [ ./service.nix ];

  options.myModule.enable = lib.mkEnableOption "my module";

  config = lib.mkIf config.myModule.enable {
    # configuration here
  };
}

OCI Image Packaging

For airgapped deployments, package images as store paths:

# Single image to OCI tarball
imagePackage = pkgs.runCommand "image-name" {
  buildInputs = [ pkgs.skopeo ];
} ''
  skopeo copy docker://registry/image:tag oci-archive:$out
'';

Helm + Kustomize in Nix

Render manifests at build time:

manifests = pkgs.runCommand "manifests" {
  buildInputs = [ pkgs.kubernetes-helm pkgs.kustomize ];
} ''
  helm template release ${./chart} --namespace ns > base.yaml
  kustomize build ${./overlays} > $out
'';

Detailed References

For comprehensive documentation on specific topics:

| Topic | Reference File | |-------|----------------| | Nix language syntax | references/nix-language.md | | Flake inputs/outputs | references/flakes.md | | NixOS modules & options | references/nixos-modules.md | | Packaging & derivations | references/packaging.md | | DevShells & overlays | references/devshells.md | | Home Manager | references/home-manager.md |

Common Patterns

Pin nixpkgs across repos

Use inputs.X.inputs.nixpkgs.follows = "nixpkgs" to ensure consistent package versions.

Conditional module loading

imports = lib.optionals config.feature.enable [ ./optional-module.nix ];

Lazy evaluation with mkIf

Always use lib.mkIf for conditional config to avoid infinite recursion:

config = lib.mkIf config.myService.enable { /* ... */ };

Override priorities

  • lib.mkDefault (priority 1000) - easily overridable defaults
  • lib.mkForce (priority 50) - force value regardless of other definitions
  • lib.mkOverride N - custom priority (lower = higher priority)

Troubleshooting

"error: getting status of '/nix/store/...': No such file or directory"

Missing store path. Run nix build or ensure binary cache is configured.

"error: infinite recursion encountered"

Using config values in imports or not wrapping conditional config in lib.mkIf.

"error: attribute 'X' missing"

Check flake inputs match expected names. Verify follows directives.

Flake not seeing local changes

Run git add . - flakes ignore untracked files.

Skills similaires