Mettre à jour NixOS vers une nouvelle version

VérifiéPrudence

Met à jour NixOS vers une nouvelle version stable en modifiant les entrées flake épinglées (ex: nixpkgs, home-manager) et en gérant les changements cassants. Recherche les changements cassants pour la version cible, crée un plan de mise à jour, puis exécute la mise à jour avec vérification. Utilisez-la pour passer d'une version NixOS à la suivante, pas pour les mises à jour mineures de flake.lock.

Spar Skills Guide Bot
DevOpsIntermédiaire
8002/06/2026
Claude Code
#nixos#upgrade#system-administration#nix-flake#release-upgrade

Recommandé pour

Notre avis

Met à jour NixOS vers une nouvelle version stable en mettant à jour les entrées flake épinglées et en gérant les changements incompatibles.

Points forts

  • Automatise la recherche des changements incompatibles et des notes de version.
  • Fournit un plan de mise à jour structuré avec des étapes claires.
  • Liste les fichiers spécifiques et les commandes pour une mise à jour sécurisée.
  • Inclut des instructions de retour en arrière faciles à suivre.

Limites

  • Nécessite que l'utilisateur examine et approuve le plan manuellement.
  • Ne fonctionne qu'avec les configurations NixOS basées sur flake.
  • Ne gère pas les mises à jour de paquets non NixOS en dehors du système.
Quand l'utiliser

Quand vous devez mettre à jour NixOS vers une nouvelle version stable et voulez vous assurer que les changements incompatibles sont traités de manière systématique.

Quand l'éviter

Quand vous avez seulement besoin de mettre à jour flake.lock au sein de la même version ou de mettre à jour des paquets individuels sans changement de version système.

Analyse de sécurité

Prudence
Score qualité90/100

The skill performs NixOS release upgrades using bash commands that alter the system (just switch, nixos-rebuild switch). While it includes a safe check step (just check) and rollback instructions, these are powerful operations that could cause breakage if misapplied. No data exfiltration or obfuscation is present.

Points d'attention
  • Uses just switch to apply system upgrades without explicit user confirmation per step; could break system if incorrect versions are used, though a check step is included.

Exemples

Upgrade to NixOS 25.11
Upgrade NixOS to version 25.11
Update NixOS release
Upgrade my NixOS system to the new release
Release upgrade with research
I want to move from NixOS 25.05 to 25.11, please help me check breaking changes and create a plan.

name: upgrade-nixos description: | This skill upgrades NixOS to a new release version (e.g., 25.05 → 25.11). Triggers: "upgrade nixos", "upgrade to new release", "update nixos version", "move to nixos 25.11", "nixos release upgrade", "upgrade system version". Researches breaking changes, updates flake inputs, guides through upgrade. Not for flake.lock updates within same release (use upgrade-flake for that).

Upgrade NixOS Release

Upgrade NixOS to a new stable release version. This involves updating version-pinned flake inputs and handling any breaking changes.

Process

  1. Check current state

    nixos-version
    nix --version
    
  2. Identify version-pinned inputs in flake/flake.nix that need updating:

    • nixpkgs (e.g., nixos-25.05nixos-25.11)
    • home-manager (e.g., release-25.05release-25.11)
    • nix-darwin (e.g., nix-darwin-25.05nix-darwin-25.11)
    • stylix (e.g., release-25.05release-25.11)
  3. Research the target release

    • Use web search to find the latest stable NixOS release
    • Check release notes for breaking changes relevant to this config
    • Verify release branches exist for home-manager, stylix, nix-darwin
  4. Identify breaking changes that affect this config:

    • Scan modules for services/packages that might be affected
    • Key areas: Hyprland, Docker, Steam, Secure Boot, impermanence
  5. Create upgrade plan (use creating-plans skill):

    • Save to thoughts/shared/issues/NN-nixos-<version>-upgrade/plan.md
    • Include exact file changes with line numbers
    • Include verification commands
    • Include rollback instructions
  6. Execute upgrade (when user is ready):

    # Edit flake/flake.nix with new versions
    just update        # Update flake.lock
    just check         # Build without applying (safe)
    just switch        # Apply the upgrade
    
  7. Post-upgrade verification:

    nixos-version
    nix --version
    docker --version
    systemctl status docker tailscaled
    hyprctl version
    

What stays pinned (don't change)

  • lanzaboote - explicit version pin (e.g., v0.4.2), not tied to NixOS releases
  • nixpkgs-unstable - always tracks unstable
  • Inputs that follow nixpkgs - automatically updated

Rollback

Print out the instructions to:

sudo nixos-rebuild switch --rollback
git checkout flake/flake.nix flake/flake.lock

$ARGUMENTS

Skills similaires