Nix (package manager) explained

Nix
Author:Eelco Dolstra

Nix is a cross-platform package manager for Unix-like systems, and a tool to instantiate and manage those systems, invented in 2003[1] by Eelco Dolstra.

Approach

The Nix package manager employs a model in which software packages are each installed into unique directories with immutable contents. These directory names correspond to cryptographic hashes that take into account all dependencies of a package, including other packages managed by Nix. As a result, Nix package names are content-identifying since packages with the same name will have had the same inputs and the same build platform, and therefore the same build result.

Implementation

Package recipes for Nix are written in the purpose-built "Nix language", a declarative, purely functional, lazily evaluated, dynamically typed programming language.[2] Distinguishing features of the Nix language are strings with "context", string interpolation, first-class file system paths, and "indented strings", which in combination allow concisely expressing dependencies between file system data when specifying the contents of new files.

Dependencies between files, as declared in the Nix language, are automatically tracked and persisted in the "Nix store".[3] New files in the Nix store are created through "derivations". A derivation is a persistent data structure that specifies an executable, arguments and environment variables for its invocation (see [[execve]]), and other files to be read from the Nix store. The executable is then run in a sandbox that prohibits access to anything but the explicitly specified input files and only allows writing to the designated output path. Nix preserves dependency information in output files by scanning for the distinctive hashes used for package directory names.

Automatic reference tracking ensures integrity of packages, even when they are transferred across machines. It also enables garbage collection of unused packages when no other package depends on them. At the cost of greater storage requirements, all upgrades in Nix are guaranteed to be both atomic and capable of efficient rollback. Unique directory names allow installing many packages with differing versions of shared libraries, and is claimed to eliminate so-called dependency hell.[4] This also lets multiple users safely install software on the same system without administrator privileges. As a result, the Nix package management and deployment model advertises more reliable, reproducible, and portable packages.[5] [6]

Nix has full support for Linux, macOS, and WSL, and can safely be installed side-by-side with another package manager.

Nixpkgs

Nixpkgs is the package repository built upon the Nix package manager. According to Repology, as of July 2024 it contains more than 110,000 packages[7] and has a higher number of up-to-date packages than any other package repository.[8] Operating systems supported by Nixpkgs are primarily Linux and Darwin, with some support for Windows and BSD variants. Supported CPU architectures include 64-bit x86 and ARM. Packages for these architectures are built regularly, using a continuous integration service called Hydra,[9] and the results of these builds are uploaded to a public binary cache.[10] When Nix installs a package, it checks this cache and downloads the binary package to avoid building it locally. Nixpkgs is developed in a single Git repository on GitHub.[11] Beside packages, it also contains the source code for NixOS.

Projects using Nix

NixOS[12] is a Linux distribution that uses Nix for managing the entire system configuration, including the Linux kernel.[13]

Nix is used for software packaging and distribution in CERN's LHCb experiment.[14] Nix underlies the distributed software development platforms Replit[15] and Google IDX.[16]

Forks and alternative implementations

In 2021, a reimplementation by the name Tvix was announced,[17] with the goals of modularity, full compatibility with Nixpkgs, and improved evaluator performance. As of 2024, Tvix has an evaluator[18] and a store implementation,[19] though the authors do not consider the project yet stable or ready for use in production. Tvix is written primarily in Rust.[20]

In 2024, a team of volunteers released the first version of Lix,[21] a fork of Nix focused on correctness and compatibility that uses the Meson build automation system. The project intends to gradually rewrite parts of the code in Rust.

See also

another declarative package manager, and early clone of Nix, using GNU Guile for configuration and customization

a build automation utility similar to make, and early precursor to Nix

External links

Notes and References

  1. Book: Dolstra, Eelco . Software Configuration Management . 2003 . 978-3-540-14036-8 . Lecture Notes in Computer Science . 2649 . 102–117 . Integrating Software Construction and Software Deployment . 10.1007/3-540-39195-9_8 . https://nixos.org/~eelco/pubs/iscsd-scm11-final.pdf . https://web.archive.org/web/20190421081837/https://nixos.org/~eelco/pubs/iscsd-scm11-final.pdf . 2019-04-21 . dead.
  2. Web site: Nix Reference Manual: Nix Language. 4 March 2024.
  3. Web site: Nix Reference Manual: Nix Store. 4 March 2024.
  4. Web site: Prins . Pjotr . Suresh . Jeeva . Dolstra . Eelco . Nix fixes dependency hell on all Linux distributions . Linux.com . 11 July 2023 . 22 December 2008.
  5. Dolstra . Eelco . de Jonge . Merijn . Visser . Eelco . Nix: A Safe and Policy-Free System for Software Deployment . LISA '04: Proceedings of the 18th USENIX Conference on System Administration . November 2004 . 79–92 . 11 July 2023.
  6. Ph.D. . Dolstra . Eelco . The Purely Functional Software Deployment Model . 2006 . 11 July 2023 . Utrecht University.
  7. Web site: Nixpkgs unstable repository information - Repology . https://web.archive.org/web/20180603203722/https://repology.org/repository/nix_unstable . 2018-06-03.
  8. Web site: Repository statistics - Repology .
  9. Web site: RFC 0046 - Platform Support Tiers. GitHub.
  10. Web site: NixOS official binary cache.
  11. Web site: Nixpkgs github repository . .
  12. Web site: Nix & NixOS | Reproducible builds and deployments. nixos.org.
  13. Dolstra . Eelco . Löh . Andres . Pierron . Nicolas . NixOS: A Purely Functional Linux Distribution . ICFP 2008: 13th ACM SIGPLAN International Conference on Functional Programming . September 2008 . 367–378 .
  14. Web site: Burr . Chris . Clemencic . Marco . Couturier . Ben . 2018 . Software packaging and distribution for LHCb using Nix .
  15. Web site: Replit . 2023-05-25 . Replit — Super Colliding Nix Stores: Nix Flakes for Millions of Developers . 2024-03-05 . Replit Blog.
  16. Web site: Customize your IDX workspace Project IDX . 2024-03-05 . Google for Developers . en.
  17. Web site: TVL's blog: Tvix: We are rewriting Nix . 2024-05-19 . tvl.fyi.
  18. Web site: TVL's blog: Tvix Status - September '22 . 2024-05-19 . tvl.fyi.
  19. Web site: TVL's blog: Tvix Status - February '24 . 2024-05-19 . tvl.fyi.
  20. Web site: tvix - depot - Sourcegraph . 2024-05-19 . cs.tvl.fyi.
  21. Web site: Lix About Lix . 2024-05-19 . lix.systems.