2020-07-22 18:27:23 +00:00
# Introduction
2020-07-22 11:51:11 +00:00
2024-05-05 22:32:20 +00:00
Lix is an implementation of Nix, a powerful, _purely functional_ package management system.
This means that it treats packages like values in purely functional programming languages such as Haskell — they are built by functions that don’ t have side-effects, and they never change after they have been built.
Lix stores packages in the _Nix store_ , usually the directory `/nix/store` , where each package has its own unique subdirectory such as
2020-07-22 11:51:11 +00:00
/nix/store/b6gvzjyb2pg0kjfwrjmg1vfhh54ad73z-firefox-33.1/
where `b6gvzjyb2pg0…` is a unique identifier for the package that
captures all its dependencies (it’ s a cryptographic hash of the
package’ s build dependency graph). This enables many powerful
features.
## Multiple versions
You can have multiple versions or variants of a package
installed at the same time. This is especially important when
different applications have dependencies on different versions of the
same package — it prevents the “DLL hell”. Because of the hashing
scheme, different versions of a package end up in different paths in
the Nix store, so they don’ t interfere with each other.
An important consequence is that operations like upgrading or
uninstalling an application cannot break other applications, since
these operations never “destructively” update or delete files that are
used by other packages.
## Complete dependencies
2024-05-05 22:32:20 +00:00
Lix helps you make sure that package dependency specifications are
2020-07-22 11:51:11 +00:00
complete. In general, when you’ re making a package for a package
management system like RPM, you have to specify for each package what
its dependencies are, but there are no guarantees that this
specification is complete. If you forget a dependency, then the
package will build and work correctly on _your_ machine if you have
the dependency installed, but not on the end user's machine if it's
not there.
2024-05-05 22:32:20 +00:00
Since Lix on the other hand doesn’ t install packages in “global”
2020-07-22 11:51:11 +00:00
locations like `/usr/bin` but in package-specific directories, the
risk of incomplete dependencies is greatly reduced. This is because
tools such as compilers don’ t search in per-packages directories such
as `/nix/store/5lbfaxb722zp…-openssl-0.9.8d/include` , so if a package
builds correctly on your system, this is because you specified the
dependency explicitly. This takes care of the build-time dependencies.
Once a package is built, runtime dependencies are found by scanning
binaries for the hash parts of Nix store paths (such as `r8vvq9kq…` ).
This sounds risky, but it works extremely well.
## Multi-user support
2024-05-05 22:32:20 +00:00
Lix has multi-user support.
This means that non-privileged users can securely install software, and it is considered a bug if users can trample on each other.
Each user can have a different _profile_ , a set of packages in the Nix store that appear in the user’ s `PATH` .
If a user installs a package that another user has already installed previously, the package won’ t be built or downloaded a second time.
At the same time, it is not possible for one user to inject a Trojan horse into a package that might be used by another user.
2020-07-22 11:51:11 +00:00
## Atomic upgrades and rollbacks
Since package management operations never overwrite packages in the
Nix store but just add new versions in different paths, they are
_atomic_. So during a package upgrade, there is no time window in
which the package has some files from the old version and some files
from the new version — which would be bad because a program might well
crash if it’ s started during that period.
And since packages aren’ t overwritten, the old versions are still
there after an upgrade. This means that you can _roll back_ to the
old version:
2020-07-31 13:43:25 +00:00
```console
2023-04-30 13:52:38 +00:00
$ nix-env --upgrade --attr nixpkgs.some-package
2020-07-31 13:43:25 +00:00
$ nix-env --rollback
```
2020-07-22 11:51:11 +00:00
## Garbage collection
When you uninstall a package like this…
2020-07-31 13:43:25 +00:00
```console
$ nix-env --uninstall firefox
```
2020-07-22 11:51:11 +00:00
the package isn’ t deleted from the system right away (after all, you
might want to do a rollback, or it might be in the profiles of other
users). Instead, unused packages can be deleted safely by running the
_garbage collector_:
2020-07-31 13:43:25 +00:00
```console
$ nix-collect-garbage
```
2020-07-22 11:51:11 +00:00
This deletes all packages that aren’ t in use by any user profile or by
a currently running program.
## Functional package language
Packages are built from _Nix expressions_ , which is a simple
functional language. A Nix expression describes everything that goes
2022-11-06 11:25:21 +00:00
into a package build task (a “derivation”): other packages, sources,
2020-07-22 11:51:11 +00:00
the build script, environment variables for the build script, etc.
2024-05-05 22:32:20 +00:00
Lix tries very hard to ensure that Nix expressions are
2020-07-22 11:51:11 +00:00
_deterministic_: building a Nix expression twice should yield the same
result.
Because it’ s a functional language, it’ s easy to support
building variants of a package: turn the Nix expression into a
function and call it any number of times with the appropriate
arguments. Due to the hashing scheme, variants don’ t conflict with
each other in the Nix store.
## Transparent source/binary deployment
Nix expressions generally describe how to build a package from
source, so an installation action like
2020-07-31 13:43:25 +00:00
```console
2023-04-30 13:52:38 +00:00
$ nix-env --install --attr nixpkgs.firefox
2020-07-31 13:43:25 +00:00
```
2020-07-22 11:51:11 +00:00
_could_ cause quite a bit of build activity, as not only Firefox but
also all its dependencies (all the way up to the C library and the
2021-11-03 16:11:20 +00:00
compiler) would have to be built, at least if they are not already in the
2020-07-22 11:51:11 +00:00
Nix store. This is a _source deployment model_ . For most users,
building from source is not very pleasant as it takes far too long.
2024-05-05 22:32:20 +00:00
However, Lix can automatically skip building from source and instead
2020-07-22 11:51:11 +00:00
use a _binary cache_ , a web server that provides pre-built
binaries. For instance, when asked to build
2024-05-05 22:32:20 +00:00
`/nix/store/b6gvzjyb2pg0…-firefox-33.1` from source, Lix would first
2020-07-22 11:51:11 +00:00
check if the file `https://cache.nixos.org/b6gvzjyb2pg0….narinfo`
exists, and if so, fetch the pre-built binary referenced from there;
otherwise, it would fall back to building from source.
## Nix Packages collection
2024-05-05 22:32:20 +00:00
We provide a large set of Nix expressions containing tens of thousands of existing Unix packages, the _Nix Packages collection_ (Nixpkgs).
2020-07-22 11:51:11 +00:00
## Managing build environments
2024-05-05 22:32:20 +00:00
Lix is extremely useful for developers as it makes it easy to
2020-07-22 11:51:11 +00:00
automatically set up the build environment for a package. Given a Nix
expression that describes the dependencies of your package, the
command `nix-shell` will build or download those dependencies if
they’ re not already in your Nix store, and then start a Bash shell in
which all necessary environment variables (such as compiler search
paths) are set.
For example, the following command gets all dependencies of the
Pan newsreader, as described by [its
Nix expression](https://github.com/NixOS/nixpkgs/blob/master/pkgs/applications/networking/newsreaders/pan/default.nix):
2020-07-31 13:43:25 +00:00
```console
2023-04-30 13:52:38 +00:00
$ nix-shell '< nixpkgs > ' --attr pan
2020-07-31 13:43:25 +00:00
```
2020-07-22 11:51:11 +00:00
You’ re then dropped into a shell where you can edit, build and test
the package:
2020-07-31 13:43:25 +00:00
```console
2021-01-01 01:17:37 +00:00
[nix-shell]$ unpackPhase
2020-07-31 13:43:25 +00:00
[nix-shell]$ cd pan-*
2021-01-01 01:17:37 +00:00
[nix-shell]$ configurePhase
[nix-shell]$ buildPhase
2020-07-31 13:43:25 +00:00
[nix-shell]$ ./pan/gui/pan
```
2020-07-22 11:51:11 +00:00
## Portability
2024-05-05 22:32:20 +00:00
Lix runs on Linux and macOS.
2020-07-22 11:51:11 +00:00
## NixOS
2024-05-05 22:32:20 +00:00
NixOS is a Linux distribution based on Nix technology. It uses Nix not just for
2020-07-22 11:51:11 +00:00
package management but also to manage the system configuration (e.g.,
to build configuration files in `/etc` ). This means, among other
things, that it is easy to roll back the entire configuration of the
system to an earlier state. Also, users can install software without
root privileges. For more information and downloads, see the [NixOS
homepage](https://nixos.org/).
## License
2024-05-05 22:32:20 +00:00
Lix is released under the terms of the [GNU LGPLv2.1 or (at your
2020-07-22 11:51:11 +00:00
option) any later
version](http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html).