Jump to content

Nix ecosystem: Difference between revisions

From Official NixOS Wiki
imported>Nix
m move to pedias category
Ardenet (talk | contribs)
Marked this version for translation
 
(32 intermediate revisions by 16 users not shown)
Line 1: Line 1:
The ''Nix Ecosystem'' is a collection of technologies designed to reproducibly build and declaratively configure and manage packages and systems as well as their dependencies. It achieves this by translating the functional paradigm from the program to the system domain by utilizing a dynamic, functional and lazy DSL called the [[Nix Expression Language]] for specifying reproducible builds.  
<languages/>
<translate>
<!--T:1-->
The '''Core Nix Ecosystem''' is a collection of technologies designed to reproducibly build and declaratively configure and manage packages and systems as well as their dependencies. It achieves this by translating the functional paradigm from the program to the system domain by utilizing a dynamic, functional and lazy DSL called the [[<tvar name=1>Special:MyLanguage/Overview of the Nix Language</tvar>|Nix Language]] for specifying reproducible builds.  


== Open source software ==
<!--T:2-->
In addition there are many other [[<tvar name=1>Special:MyLanguage/applications</tvar>|applications]] ('''''Extended Nix Ecosystem''''') developed by the Nix community, utilizing and supporting these core technologies.
 
== Official ecosystem == <!--T:3-->
</translate>


{| class="wikitable"
{| class="wikitable"
|+ Core Components of the Nix Ecosystem:
|+ <translate><!--T:4--> Core Components of the Nix Ecosystem</translate>
|-
| ''Component''
| ''Manual''
| ''Description''
| ''Use''
| ''License''
|-
|-
| [[Nix Package Manager | Nix]]
! <translate><!--T:16--> Component</translate>
| [https://nixos.org/nix/manual/ Nix Manual]
! <translate><!--T:17--> Manual</translate>
| A package manager that parses Nix expressions specifying reproducible build, putting the result in a store address with a hash of the dependency tree, sidestepping dependency hell and supporting multiversion installs and rollbacks.
! <translate><!--T:18--> Description</translate>
| Reproducible builds & package management in Linux & Darwin
! <translate><!--T:19--> Use</translate>
| LGPL-2.1
! <translate><!--T:20--> License</translate>
|-  
|-  
| [[NixOS]]
| [[Special:MyLanguage/NixOS|NixOS]]
| [https://nixos.org/nixos/manual/ NixOS Manual]
| <translate><!--T:21--> [https://nixos.org/nixos/manual/ NixOS Manual]</translate>
| A Linux distribution with ''all'' components built by Nix, and thus supporting reproducible and declarative system-wide configuration management as well as atomic upgrades and rollbacks.  
| <translate><!--T:22--> A Linux distribution with ''all'' components built by Nix, and thus supporting reproducible and declarative system-wide configuration management as well as atomic upgrades and rollbacks.</translate>
| Declaratively configure desktops, servers & clusters
| <translate><!--T:23--> Declaratively configure desktops, servers & clusters</translate>
| MIT
| MIT
|-
|-
| [[Nixpkgs]]
| [[Special:MyLanguage/Nixpkgs|Nixpkgs]]
| [https://nixos.org/nixpkgs/manual/ Nixpkgs Manual]
| <translate><!--T:24--> [https://nixos.org/nixpkgs/manual/ Nixpkgs Manual]</translate>
| The largest community maintained Nix package and NixOS module repository; standard releases of NixOS are hosted here.
| <translate><!--T:25--> The largest community maintained Nix package and NixOS module repository; standard releases of NixOS are hosted here.</translate>
| Share Nix packages & NixOS modules
| <translate><!--T:26--> Share Nix packages & NixOS modules</translate>
| MIT
| MIT
|-
|-
| [[NixOps]]
| [[Special:MyLanguage/Hydra|Hydra]]
| [https://nixos.org/nixops/manual/ NixOps Manual]
| <translate><!--T:27--> [https://nixos.org/hydra/manual/ Hydra Manual]</translate>
| A Nix based deployment and provisioning tool allowing declarative specification of remote NixOS systems, VMs and containers; supports AWS, Hetzner, GCE and some other cloud providers out of box.
| <translate><!--T:28--> A Nix based continuous build system.</translate>
| Deploy & provision NixOS systems, VMs & containers
| <translate><!--T:29--> CI build farms</translate>
| LGPL-3.0
| GPL-3.0
|-
|-
| [[Hydra]]
| [[Special:MyLanguage/Nix|Nix]]
| [https://nixos.org/hydra/manual/ Hydra Manual]
| <translate><!--T:30--> [https://nixos.org/nix/manual/ Nix Manual]</translate>
| A Nix based continuous build system.
| <translate><!--T:31--> A package manager that parses Nix expressions specifying reproducible build, putting the result in a store address with a hash of the dependency tree, sidestepping dependency hell and supporting multiversion installs and rollbacks.</translate>
| CI build farms
| <translate><!--T:32--> Reproducible builds & package management in Linux & Darwin</translate>
| GPL-3.0
| LGPL-2.1
|}  
|}  


In addition there are many other [[applications]] developed by the Nix community, utilizing and supporting these core technologies.


[[File:Nixos-stack2.png|center|link=]]
{| style="max-width: 36rem; margin: auto;"
|+ <translate><!--T:5--> '''The NixOS core ecosystem stack'''</translate>
| style="text-align: center; border: 1px solid var(--border-color-base); background: var(--background-color-neutral); padding: 1.6rem" width="2%"|
<div style="font-size: 1.3em; font-weight: bold">NixOS</div>
<translate><!--T:33--> A Linux distribution and configuration system built using Nixpkgs.</translate>
|-
| style="text-align: center; border: 1px solid var(--border-color-base); background: var(--background-color-neutral); padding: 1.6rem" width="2%"|
<div style="font-size: 1.3em; font-weight: bold">Nixpkgs</div>
<translate><!--T:34--> A large, community-maintained repository of packages.</translate>
| style="text-align: center; border: 1px solid var(--border-color-base); background: var(--background-color-neutral); padding: 1.6rem" width="2%"|
<div style="font-size: 1.3em; font-weight: bold">Hydra</div>
<translate><!--T:35--> A continuous build system built on Nix.</translate>
|-
| style="text-align: center; border: 1px solid var(--border-color-base); background: var(--background-color-neutral); padding: 1.6rem" width="2%" colspan="2"|
<div style="font-size: 1.3em; font-weight: bold">Nix</div>
<translate><!--T:36--> A pure and functional build system.</translate>
|}
 
<translate>
== Usage of NixOS == <!--T:6-->
 
<!--T:37-->
Users install the ''NixOS'' distribution on their computers just as any other Linux distribution. They read about packages to install and configuration options in ''Nixpkgs'' via https://search.nixos.org and this wiki. They use the ''Nix'' language to declaratively describe in a text file what software packages should be installed and how the system should be configured. They run 2 command line programs in a terminal to transform the system into the described system. They use the system as any other Linux system.
 
== Development of NixOS == <!--T:7-->


== Services ==
<!--T:38-->
Note: not required for any use of Nix nor affiliated with the NixOS Foundation.
Developers of ''NixOS'' mainly work on ''Nixpkgs''. ''NixOS'' development itself is compromised of three large areas as well as some others which are smaller by volume (but no less important). The major ones include packaging, the module system, and documentation.


* [https://cachix.org Cachix:] binary caches as a service. Free for public caches, subscription for private token-protected caches
<!--T:11-->
* [https://hercules-ci.com Hercules CI:] simplify your CI setup with stateless build agents. Free for open source, per-user subscription for private repositories.
* Packaging is done in ''Nixpkgs'' and is not exclusive to ''NixOS'' or even Linux-based platforms. Maintainers of packages which are not exclusive to ''NixOS'' (such as tooling required to run the distribution itself) usually take care of multiple platforms although not strictly required.
* [https://nixbuild.net/ nixbuild.net] (private beta): remote Nix builders as a service. Pay-per-use.
 
<!--T:12-->
* The module system is the way in which services running on ''NixOS'' are primarily configured. This area stretches from "low-level" configuration such as ''systemd'' unit files or providing custom kernel configuration up to configuration file generation for specific services. The module system is the primary way for users to configure ''NixOS'', and lives in the <code>nixos/</code> subdirector of ''Nixpkgs''.
 
<!--T:13-->
* Documentation is largely embedded in packaging and module system data, although free-standing markdown files are also contained in the ''Nixpkgs'' repository. Documentation also includes maintaining the website, Wiki, and other aspects of the wider ecosystem. The first two categories are almost exclusively ''Nix'' language code written in text files, while the latter is a mix of ''Nix'' code, markdown files, and various other formats.
 
<!--T:14-->
All contributions to ''Nixpkgs'', regardless of whether they affect ''NixOS'' or not, are subject to peer review before being integrated into ''Nixpkgs''. Many packages alongside documentation and supplementary materials such as ISOs or tarballs are pre built on ''Hydra'' to reduce the update time for ''NixOS'' users.
 
<!--T:15-->
Those three categories are largest by contribution volume, however many maintainers also engage in activities surrounding the NixOS foundation, maintaining the infrastructure on which website, ''Hydra'', and other tools run on, or developing tooling required for NixOS.
</translate>
 
{| class="wikitable"
|+ <translate><!--T:9--> Various examples of ''NixOS'' development along with links.</translate>
! <translate><!--T:39--> Type of development</translate> !! <translate><!--T:40--> Location of Development</translate> !! <translate><!--T:41--> Examples</translate>
|-
| <translate><!--T:42--> Platform Agnostic Packaging</translate> || ''Nixpkgs'' || <translate><!--T:43--> [<tvar name=1>https://github.com/NixOS/nixpkgs/blob/bf3287dac860542719fe7554e21e686108716879/pkgs/tools/misc/coreutils/default.nix</tvar> coreutils package], [<tvar name=2>https://github.com/NixOS/nixpkgs/tree/5fe6820251dfab92c84ff356a7c7c336f8d8490c/pkgs/stdenv</tvar> ''stdenv'' framework], [<tvar name=3>https://github.com/NixOS/nixpkgs/blob/5fe6820251dfab92c84ff356a7c7c336f8d8490c/pkgs/applications/office/libreoffice/default.nix</tvar> Libreoffice package]</translate>
|-
| <translate><!--T:44--> Platform Agnostic Tooling</translate> || <translate><!--T:45--> ''Nixpkgs'' and various repositories</translate> || <translate><!--T:46--> [<tvar name=1>https://github.com/NixOS/nix</tvar> upstream/default Nix implementation (CppNix)], [<tvar name=2>https://github.com/NixOS/hydra</tvar> ''Hydra'' source code], [<tvar name=3>https://github.com/NixOS/nixpkgs-merge-bot</tvar> ''Nixpkgs'' merge bot]</translate>
|-
| <translate><!--T:47--> ''NixOS'' Tooling</translate> || <translate><!--T:48--> mostly ''Nixpkgs''</translate> || <translate><!--T:49--> [<tvar name=1>https://github.com/NixOS/nixpkgs/tree/5fe6820251dfab92c84ff356a7c7c336f8d8490c/pkgs/by-name/ni/nixos-rebuild-ng</tvar> nixos-rebuild-ng source code], [<tvar name=2>https://github.com/NixOS/nixpkgs/blob/5fe6820251dfab92c84ff356a7c7c336f8d8490c/nixos/modules/installer/cd-dvd/installation-cd-minimal.nix</tvar> ''NixOS'' Installation ISOs]</translate>
|-
| <translate><!--T:50--> ''NixOS'' Module System</translate> || ''Nixpkgs'' || <translate><!--T:51--> [<tvar name=1>https://github.com/NixOS/nixpkgs/blob/master/nixos/modules/services/display-managers/default.nix</tvar> Display Manager configuration], [<tvar name=2>https://github.com/NixOS/nixpkgs/blob/master/nixos/modules/services/databases/mysql.nix</tvar> MySQL (and derivative) database configuration]</translate>
|-
| <translate><!--T:52--> Infrastructure</translate> || || <translate><!--T:53--> [<tvar name=1>https://github.com/NixOS/nixos-wiki-infra</tvar> Infrastructure for this Wiki], [<tvar name=2>https://github.com/NixOS/infra</tvar> ''NixOS'' infra]</translate>
|-
| <translate><!--T:54--> Documentation</translate> || || <translate><!--T:55--> [<tvar name=1>https://wiki.nixos.org</tvar> This Wiki], [<tvar name=2>https://github.com/NixOS/nixpkgs/blob/8d92119c540d78599ba208010c722a60958810f4/doc/stdenv/stdenv.chapter.md</tvar> ''stdenv'' documentation], [<tvar name=3>https://github.com/NixOS/nixpkgs/blob/master/nixos/doc/manual/configuration/ipv6-config.section.md</tvar> ''NixOS'' IPv6 configuration] (visible in the [<tvar name=4>https://nixos.org/manual/nixos/stable/#sec-ipv6</tvar> IPv6 section of the ''NixOS'' manual]), [<tvar name=5>https://github.com/NixOS/nixpkgs/blob/master/CONTRIBUTING.md</tvar> ''Nixpkgs'' Contribution Guidelines]</translate>
|-
| <translate><!--T:56--> Tech Organisation</translate> || || <translate><!--T:57--> [<tvar name=1>https://github.com/NixOS/nixpkgs/issues/390768</tvar> ''NixOS'' RelEng], [<tvar name=2>https://github.com/NixOS/rfcs/</tvar> ''Nix'' and ''NixOS'' RFCs]</translate>
|-
| <translate><!--T:58--> Other</translate> || || <translate><!--T:59--> [<tvar name=1>https://github.com/NixOS/nixos-artwork</tvar> ''NixOS'' artwork], [<tvar name=2>https://discourse.nixos.org/</tvar> ''NixOS'' (and related) discourse], [<tvar name=3>https://github.com/NixOS/foundation</tvar> ''NixOS Foundation'']</translate>
|}


<translate>
<!--T:10-->
See also: [https://github.com/NixOS/org Nix organisation repository]
</translate>


[[Category:Pedias]]
[[Category:Pedias]]
[[Category:Ecosystem]]
[[Category:NixOS]]
[[Category:Incomplete]]
[[Category:nix]]

Latest revision as of 08:51, 8 March 2026

The Core Nix Ecosystem is a collection of technologies designed to reproducibly build and declaratively configure and manage packages and systems as well as their dependencies. It achieves this by translating the functional paradigm from the program to the system domain by utilizing a dynamic, functional and lazy DSL called the Nix Language for specifying reproducible builds.

In addition there are many other applications (Extended Nix Ecosystem) developed by the Nix community, utilizing and supporting these core technologies.

Official ecosystem

Core Components of the Nix Ecosystem
Component Manual Description Use License
NixOS NixOS Manual A Linux distribution with all components built by Nix, and thus supporting reproducible and declarative system-wide configuration management as well as atomic upgrades and rollbacks. Declaratively configure desktops, servers & clusters MIT
Nixpkgs Nixpkgs Manual The largest community maintained Nix package and NixOS module repository; standard releases of NixOS are hosted here. Share Nix packages & NixOS modules MIT
Hydra Hydra Manual A Nix based continuous build system. CI build farms GPL-3.0
Nix Nix Manual A package manager that parses Nix expressions specifying reproducible build, putting the result in a store address with a hash of the dependency tree, sidestepping dependency hell and supporting multiversion installs and rollbacks. Reproducible builds & package management in Linux & Darwin LGPL-2.1


The NixOS core ecosystem stack
NixOS

A Linux distribution and configuration system built using Nixpkgs.

Nixpkgs

A large, community-maintained repository of packages.

Hydra

A continuous build system built on Nix.

Nix

A pure and functional build system.

Usage of NixOS

Users install the NixOS distribution on their computers just as any other Linux distribution. They read about packages to install and configuration options in Nixpkgs via https://search.nixos.org and this wiki. They use the Nix language to declaratively describe in a text file what software packages should be installed and how the system should be configured. They run 2 command line programs in a terminal to transform the system into the described system. They use the system as any other Linux system.

Development of NixOS

Developers of NixOS mainly work on Nixpkgs. NixOS development itself is compromised of three large areas as well as some others which are smaller by volume (but no less important). The major ones include packaging, the module system, and documentation.

  • Packaging is done in Nixpkgs and is not exclusive to NixOS or even Linux-based platforms. Maintainers of packages which are not exclusive to NixOS (such as tooling required to run the distribution itself) usually take care of multiple platforms although not strictly required.
  • The module system is the way in which services running on NixOS are primarily configured. This area stretches from "low-level" configuration such as systemd unit files or providing custom kernel configuration up to configuration file generation for specific services. The module system is the primary way for users to configure NixOS, and lives in the nixos/ subdirector of Nixpkgs.
  • Documentation is largely embedded in packaging and module system data, although free-standing markdown files are also contained in the Nixpkgs repository. Documentation also includes maintaining the website, Wiki, and other aspects of the wider ecosystem. The first two categories are almost exclusively Nix language code written in text files, while the latter is a mix of Nix code, markdown files, and various other formats.

All contributions to Nixpkgs, regardless of whether they affect NixOS or not, are subject to peer review before being integrated into Nixpkgs. Many packages alongside documentation and supplementary materials such as ISOs or tarballs are pre built on Hydra to reduce the update time for NixOS users.

Those three categories are largest by contribution volume, however many maintainers also engage in activities surrounding the NixOS foundation, maintaining the infrastructure on which website, Hydra, and other tools run on, or developing tooling required for NixOS.

Various examples of NixOS development along with links.
Type of development Location of Development Examples
Platform Agnostic Packaging Nixpkgs coreutils package, stdenv framework, Libreoffice package
Platform Agnostic Tooling Nixpkgs and various repositories upstream/default Nix implementation (CppNix), Hydra source code, Nixpkgs merge bot
NixOS Tooling mostly Nixpkgs nixos-rebuild-ng source code, NixOS Installation ISOs
NixOS Module System Nixpkgs Display Manager configuration, MySQL (and derivative) database configuration
Infrastructure Infrastructure for this Wiki, NixOS infra
Documentation This Wiki, stdenv documentation, NixOS IPv6 configuration (visible in the IPv6 section of the NixOS manual), Nixpkgs Contribution Guidelines
Tech Organisation NixOS RelEng, Nix and NixOS RFCs
Other NixOS artwork, NixOS (and related) discourse, NixOS Foundation

See also: Nix organisation repository