Nix (package manager)/fr: Difference between revisions
Created page with "== Utilisation ==" |
Created page with "Category:Pedias Category:Nix Category:Incomplete Category:Software" |
||
| (23 intermediate revisions by the same user not shown) | |||
| Line 1: | Line 1: | ||
<languages/> | <languages/> | ||
{{Navbox Nix}} | {{Navbox Nix}} | ||
{{Disambiguation|message=Cet article traite du gestionnaire de paquets Nix. À ne pas confondre avec l'[[écosystème Nix]], le [[langage Nix]] ou la [[commande Nix]].}} | {{Disambiguation|message=Cet article traite du gestionnaire de paquets Nix. À ne pas confondre avec l'[[Nix ecosystem|écosystème Nix]], le [[Nix (language)|langage Nix]] ou la [[Nix (command)|commande Nix]].}} | ||
Nix est un gestionnaire de paquets et un système de compilation qui analyse des instructions de compilation reproductibles spécifiées dans le [[langage d'expression Nix]], un langage fonctionnel pur avec évaluation paresseuse. Les expressions Nix sont des fonctions pures<ref>Les valeurs ne peuvent pas changer pendant le calcul. Les fonctions produisent toujours le même résultat si leur entrée ne change pas. </ref>qui prennent des dépendances en arguments et produisent une « [[Derivations|dérivation]] » spécifiant un environnement de compilation reproductible pour le paquet. Nix stocke les résultats de la compilation à des adresses uniques spécifiées par un hachage de l'arborescence complète des dépendances, créant ainsi un magasin de paquets immuable (également appelé [[#Nix store|nix store]]) qui permet des mises à jour atomiques, des retours en arrière et l'installation simultanée de différentes versions d'un paquet, éliminant ainsi pratiquement [https://en.wikipedia.org/wiki/Dependency_hell l'enfer des dépendances]. | Nix est un gestionnaire de paquets et un système de compilation qui analyse des instructions de compilation reproductibles spécifiées dans le [[Nix Expression Language|langage d'expression Nix]], un langage fonctionnel pur avec évaluation paresseuse. Les expressions Nix sont des fonctions pures<ref>Les valeurs ne peuvent pas changer pendant le calcul. Les fonctions produisent toujours le même résultat si leur entrée ne change pas. </ref>qui prennent des dépendances en arguments et produisent une « [[Derivations|dérivation]] » spécifiant un environnement de compilation reproductible pour le paquet. Nix stocke les résultats de la compilation à des adresses uniques spécifiées par un hachage de l'arborescence complète des dépendances, créant ainsi un magasin de paquets immuable (également appelé [[#Nix store|nix store]]) qui permet des mises à jour atomiques, des retours en arrière et l'installation simultanée de différentes versions d'un paquet, éliminant ainsi pratiquement [https://en.wikipedia.org/wiki/Dependency_hell l'enfer des dépendances]. | ||
<span id="Usage"></span> | <span id="Usage"></span> | ||
== Utilisation == | == Utilisation == | ||
=== Installation === | === Installation === | ||
Sous [[NixOS]], Nix est installé automatiquement. | |||
Sur d'autres distributions Linux ou sur macOS, vous pouvez installer Nix en suivant la [https://nixos.org/manual/nix/stable/installation/installation section d'installation du manuel de Nix]. | |||
< | <span id="Nix_commands"></span> | ||
=== Nix | === Commandes Nix === | ||
Les [[Nix (command line utilities)|commandes Nix]] sont décrites dans le [https://nixos.org/manual/nix/stable/command-ref/command-ref manuel de référence de Nix] : commandes principales, utilitaires et commandes expérimentales. Avant la version 2.0 (publiée en février 2018), les commandes étaient différentes. | |||
=== Configuration === | === Configuration === | ||
Sous NixOS, Nix peut être configuré à l'aide de l'option [https://search.nixos.org/options?query=nix. <code>nix</code>]. | |||
Nix en mode autonome se configure via le fichier <code>nix.conf</code> (qui se trouve généralement dans <code>/etc/nix/</code>). Vous trouverez plus de détails sur les options disponibles [https://nixos.org/manual/nix/stable/command-ref/conf-file dans le manuel de référence de Nix]. | |||
Vous pouvez également configurer Nix à l'aide de [[Home Manager]], qui gère les environnements déclaratifs pour un seul utilisateur. Pour une configuration à l'échelle du système, vous pouvez utiliser [https://github.com/numtide/system-manager System Manager] sous Linux et [https://github.com/LnL7/nix-darwin nix-darwin] sous macOS. | |||
< | <span id="Internals"></span> | ||
== | == En interne == | ||
=== Nix store === | === Nix store === | ||
{{Split|reason=Le Nix store est suffisamment distinct sur le plan conceptuel pour mériter un article à part entière.}} | |||
{{Split|reason= | |||
Les paquets compilés par Nix sont placés dans le « Nix store » en lecture seule, qui se trouve généralement dans <code>/nix/store</code>. Chaque paquet se voit attribuer une adresse unique spécifiée par un hachage cryptographique suivi du nom et de la version du paquet, par exemple <code>/nix/store/nawl092prjblbhvv16kxxbk6j9gkgcqm-git-2.14.1</code>. Ces préfixes hachent toutes les entrées du processus de compilation, y compris les fichiers source, l'arborescence complète des dépendances, les options du compilateur, etc. Cela permet à Nix d'installer simultanément différentes versions d'un même paquet, et même différentes compilations d'une même version, par exemple des variantes compilées avec des compilateurs différents. Lors de l'ajout, de la suppression ou de la mise à jour d'un paquet, rien n'est supprimé du store; à la place, des liens symboliques vers ces paquets sont ajoutés, supprimés ou modifiés dans les « profils ». | |||
< | <span id="Cleaning_the_Nix_store"></span> | ||
==== | ==== Nettoyage du Nix store ==== | ||
Pour plus d'informations sur le nettoyage du Nix store, consultez {{NixOS Manual|name=Manuel NixOS : Chapitre - Nettoyage du Nix store|anchor=#sec-nix-gc}}. | |||
< | <span id="Nix_store_corruption"></span> | ||
==== Nix store | ==== Corruption du Nix store ==== | ||
Pour plus d'informations sur la réparation d'un Nix store endommagé, consultez {{NixOS Manual|name=Manuel NixOS : Chapitre - Corruption du Nix store|anchor=#sec-nix-store-corruption}}. | |||
< | <span id="Valid_Nix_store_names"></span> | ||
==== | ==== Noms valides du Nix store ==== | ||
{{main|Valid Nix store path names}} | {{main|Valid Nix store path names}} | ||
< | <span id="Profiles"></span> | ||
=== | === Profils === | ||
Afin de construire un environnement utilisateur ou système cohérent, Nix crée des liens symboliques entre les entrées du magasin Nix et des « profils ». Ceux-ci constituent l'interface par laquelle Nix permet les restaurations : le magasin étant immuable et les versions précédentes des profils étant conservées, revenir à un état antérieur revient simplement à modifier le lien symbolique vers un profil antérieur. Pour être plus précis, Nix crée des liens symboliques vers les binaires dans des entrées du magasin Nix représentant les environnements utilisateur. Ces environnements utilisateur sont ensuite liés symboliquement à des profils étiquetés stockés dans <code>/nix/var/nix/profiles</code>, qui sont à leur tour liés symboliquement au répertoire <code>~/.nix-profile</code> de l'utilisateur. | |||
=== Sandboxing === | === Sandboxing === | ||
Lorsque les compilations en bac à sable sont activées, Nix configure un environnement isolé pour chaque processus de compilation. Cela permet d'éliminer les dépendances cachées supplémentaires définies par l'environnement de compilation afin d'améliorer la reproductibilité. Cela inclut l'accès au réseau pendant la compilation en dehors des fonctions <code>fetch*</code> et aux fichiers situés en dehors du Nix store. Selon le système d'exploitation, l'accès à d'autres ressources est également bloqué (par exemple, la communication interprocessus est isolée sous Linux). | |||
Le sandboxing est activé par défaut sous Linux, et désactivé par défaut sous macOS. | |||
Dans les pull requests pour Nixpkgs, il est demandé aux contributeurs de tester les builds avec le sandboxing activé (voir <code>Testé avec le sandboxing</code> dans le modèle de pull request) car dans les builds officiels d'Hydra, le sandboxing est également utilisé. | |||
Pour configurer Nix pour le sandboxing, définissez <code>sandbox = true</code> dans <code>/etc/nix/nix.conf</code> ; pour configurer NixOS pour le sandboxing, définissez <code>nix.useSandbox = true;</code> dans <code>configuration.nix</code>. L'option <code>nix.useSandbox</code> est définie sur <code>true</code> par défaut depuis NixOS 17.09. | |||
< | <span id="Alternative_Interpreters"></span> | ||
=== | === Interpréteurs Alternatifs === | ||
Un projet est actuellement en cours pour réécrire Nix de A à Z en Rust. | |||
* [https://cs.tvl.fyi/depot/-/tree/tvix tvix] | * [https://cs.tvl.fyi/depot/-/tree/tvix tvix] | ||
Il existe également une version dérivée de Nix 2.18 développée par la communauté, baptisée Lix, qui met l'accent sur la fiabilité, la facilité d'utilisation et la croissance. Bien qu'elle ait également porté certains composants de Nix vers Rust, il ne s'agit pas d'une réécriture complète comme Tvix. | |||
* [https://lix.systems/ lix] | * [https://lix.systems/ lix] | ||
Des essais préliminaires peuvent être trouvés sur [https://riir-nix.github.io/ riir-nix] | |||
==Notes== | ==Notes== | ||
< | <références /> | ||
[[Category:Pedias]] | [[Category:Pedias]] | ||
[[Category:Nix]] | [[Category:Nix]] | ||
[[Category:Incomplete]] | [[Category:Incomplete]] | ||
[[Category:Software]] | [[Category:Software]] | ||
Latest revision as of 12:26, 13 May 2026
Nix est un gestionnaire de paquets et un système de compilation qui analyse des instructions de compilation reproductibles spécifiées dans le langage d'expression Nix, un langage fonctionnel pur avec évaluation paresseuse. Les expressions Nix sont des fonctions pures[1]qui prennent des dépendances en arguments et produisent une « dérivation » spécifiant un environnement de compilation reproductible pour le paquet. Nix stocke les résultats de la compilation à des adresses uniques spécifiées par un hachage de l'arborescence complète des dépendances, créant ainsi un magasin de paquets immuable (également appelé nix store) qui permet des mises à jour atomiques, des retours en arrière et l'installation simultanée de différentes versions d'un paquet, éliminant ainsi pratiquement l'enfer des dépendances.
Utilisation
Installation
Sous NixOS, Nix est installé automatiquement.
Sur d'autres distributions Linux ou sur macOS, vous pouvez installer Nix en suivant la section d'installation du manuel de Nix.
Commandes Nix
Les commandes Nix sont décrites dans le manuel de référence de Nix : commandes principales, utilitaires et commandes expérimentales. Avant la version 2.0 (publiée en février 2018), les commandes étaient différentes.
Configuration
Sous NixOS, Nix peut être configuré à l'aide de l'option nix.
Nix en mode autonome se configure via le fichier nix.conf (qui se trouve généralement dans /etc/nix/). Vous trouverez plus de détails sur les options disponibles dans le manuel de référence de Nix.
Vous pouvez également configurer Nix à l'aide de Home Manager, qui gère les environnements déclaratifs pour un seul utilisateur. Pour une configuration à l'échelle du système, vous pouvez utiliser System Manager sous Linux et nix-darwin sous macOS.
En interne
Nix store
Les paquets compilés par Nix sont placés dans le « Nix store » en lecture seule, qui se trouve généralement dans /nix/store. Chaque paquet se voit attribuer une adresse unique spécifiée par un hachage cryptographique suivi du nom et de la version du paquet, par exemple /nix/store/nawl092prjblbhvv16kxxbk6j9gkgcqm-git-2.14.1. Ces préfixes hachent toutes les entrées du processus de compilation, y compris les fichiers source, l'arborescence complète des dépendances, les options du compilateur, etc. Cela permet à Nix d'installer simultanément différentes versions d'un même paquet, et même différentes compilations d'une même version, par exemple des variantes compilées avec des compilateurs différents. Lors de l'ajout, de la suppression ou de la mise à jour d'un paquet, rien n'est supprimé du store; à la place, des liens symboliques vers ces paquets sont ajoutés, supprimés ou modifiés dans les « profils ».
Nettoyage du Nix store
Pour plus d'informations sur le nettoyage du Nix store, consultez Manuel NixOS : Chapitre - Nettoyage du Nix store.
Corruption du Nix store
Pour plus d'informations sur la réparation d'un Nix store endommagé, consultez Manuel NixOS : Chapitre - Corruption du Nix store.
Noms valides du Nix store
- Main article: Valid Nix store path names
Profils
Afin de construire un environnement utilisateur ou système cohérent, Nix crée des liens symboliques entre les entrées du magasin Nix et des « profils ». Ceux-ci constituent l'interface par laquelle Nix permet les restaurations : le magasin étant immuable et les versions précédentes des profils étant conservées, revenir à un état antérieur revient simplement à modifier le lien symbolique vers un profil antérieur. Pour être plus précis, Nix crée des liens symboliques vers les binaires dans des entrées du magasin Nix représentant les environnements utilisateur. Ces environnements utilisateur sont ensuite liés symboliquement à des profils étiquetés stockés dans /nix/var/nix/profiles, qui sont à leur tour liés symboliquement au répertoire ~/.nix-profile de l'utilisateur.
Sandboxing
Lorsque les compilations en bac à sable sont activées, Nix configure un environnement isolé pour chaque processus de compilation. Cela permet d'éliminer les dépendances cachées supplémentaires définies par l'environnement de compilation afin d'améliorer la reproductibilité. Cela inclut l'accès au réseau pendant la compilation en dehors des fonctions fetch* et aux fichiers situés en dehors du Nix store. Selon le système d'exploitation, l'accès à d'autres ressources est également bloqué (par exemple, la communication interprocessus est isolée sous Linux).
Le sandboxing est activé par défaut sous Linux, et désactivé par défaut sous macOS.
Dans les pull requests pour Nixpkgs, il est demandé aux contributeurs de tester les builds avec le sandboxing activé (voir Testé avec le sandboxing dans le modèle de pull request) car dans les builds officiels d'Hydra, le sandboxing est également utilisé.
Pour configurer Nix pour le sandboxing, définissez sandbox = true dans /etc/nix/nix.conf ; pour configurer NixOS pour le sandboxing, définissez nix.useSandbox = true; dans configuration.nix. L'option nix.useSandbox est définie sur true par défaut depuis NixOS 17.09.
Interpréteurs Alternatifs
Un projet est actuellement en cours pour réécrire Nix de A à Z en Rust.
Il existe également une version dérivée de Nix 2.18 développée par la communauté, baptisée Lix, qui met l'accent sur la fiabilité, la facilité d'utilisation et la croissance. Bien qu'elle ait également porté certains composants de Nix vers Rust, il ne s'agit pas d'une réécriture complète comme Tvix.
Des essais préliminaires peuvent être trouvés sur riir-nix
Notes
<références />
- ↑ Les valeurs ne peuvent pas changer pendant le calcul. Les fonctions produisent toujours le même résultat si leur entrée ne change pas.
