Nix
Common Environment Variables
Common Environment Variables
Most Nix commands interpret the following environment variables.
Configuration environment variables
The following environment variables affect how Nix loads its configuration. See the configuration file documentation for full details.
-
Overrides the system configuration directory.
-
Overrides the user configuration file locations.
-
Provides configuration settings inline.
Store setting environment variables
-
Normally, the Nix store directory (typically
/nix/store) is not allowed to contain any symlink components. This is to prevent “impure” builds. Builders sometimes “canonicalise” paths by resolving all symlink components. Thus, builds on different machines (with/nix/storeresolving to different locations) could yield different results. This is generally not a problem, except when builds are deployed to machines where/nix/storeresolves differently. If you are sure that you’re not going to do that, you can setNIX_IGNORE_SYMLINK_STOREto1.Note that if you’re symlinking the Nix store so that you can put it on another file system than the root file system, on Linux you’re better off using
bindmount points, e.g.,$ mkdir /nix $ mount -o bind /mnt/otherdisk/nix /nixConsult the mount 8 manual page for details.
-
Overrides the location of the Nix store. On Unix, the default is
/nix/store, set at compile time by thelibstore:store-dirbuild option. On Windows, there is no compile-time setting; the default is%PROGRAMDATA%\nix\store, determined at runtime using the%PROGRAMDATA%Known Folder.See the Store Types chapter; each store has a
storesetting linking back to this as its default. -
Overrides the location of the Nix log directory. On Unix, the default is
/nix/var/log/nix, set at compile time by thelog-dirbuild option. On Windows, there is no compile-time setting; the default is%PROGRAMDATA%\nix\log, determined at runtime using the%PROGRAMDATA%Known Folder.The Local Store, Local Daemon Store, and Experimental SSH Store with filesystem mounted have per-store settings that override this.
-
Overrides the location of the Nix state directory. On Unix, the default is
${localstatedir}/nix, wherelocalstatediris a compile-time build option defaulting to/nix/var. On Windows, there is no compile-time setting; the default is%PROGRAMDATA%\nix\state, determined at runtime using the%PROGRAMDATA%Known Folder.The Local Store, Local Daemon Store, and Experimental SSH Store with filesystem mounted have per-store settings that override this.
-
Overrides the path to the Unix domain socket used to communicate with the Nix daemon. Defaults to
daemon-socket/socketwithin the state directory (seeNIX_STATE_DIR).See the Local Daemon Store documentation for details on how the socket path is resolved.
-
Use the specified directory to store temporary files. In particular, this includes temporary build directories; these can take up substantial amounts of disk space. The default is
/tmp. -
Overrides the
storesetting.
Nix language evaluator settings
-
If set to
1, Nix will print some evaluation statistics, such as the number of values allocated. -
If set to
1, Nix will print how often functions were called during Nix expression evaluation. This is useful for profiling your Nix expressions. -
If Nix has been configured to use the Boehm garbage collector, this variable sets the initial size of the heap in bytes. It defaults to 384 MiB. Setting it to a low value reduces memory consumption, but will increase runtime due to the overhead of garbage collection.
-
A colon-separated list of search path entries used to resolve lookup paths.
This environment variable overrides the value of the
nix-pathconfiguration setting.It can be extended using the
-Ioption.Example
$ export NIX_PATH=/home/eelco/Dev:nixos-config=/etc/nixosIf
NIX_PATHis set to an empty string, resolving search paths will always fail.Example
$ NIX_PATH= nix-instantiate --eval '<nixpkgs>' error: file 'nixpkgs' was not found in the Nix search path (add it using $NIX_PATH or -I)
User Directories
Nix supports per-user configuration, state, and cache directories. The following environment variables override the locations for these directories:
- [user configuration directory]{#user-conf-dir}: [
NIX_CONFIG_HOME]{#env-NIX_CONFIG_HOME} - user state directory: [
NIX_STATE_HOME]{#env-NIX_STATE_HOME} - user cache directory: [
NIX_CACHE_HOME]{#env-NIX_CACHE_HOME}
When these are not set, the defaults depend on the platform:
- On Unix, the XDG base directories:
$XDG_CONFIG_HOME/nix,$XDG_STATE_HOME/nix,$XDG_CACHE_HOME/nix - On Windows, the Windows Known Folders:
%APPDATA%\nix\config,%LOCALAPPDATA%\nix\state,%LOCALAPPDATA%\nix\cache
For backwards compatibility, legacy Nix commands (e.g. nix-env, nix-channel) use dotfiles in $HOME instead of these directories unless use-xdg-base-directories is enabled.
New Nix commands (experimental) use the proper directories by default.
When use-xdg-base-directories is enabled, the configuration directory is resolved as:
$NIX_CONFIG_HOME, if it is defined- Otherwise, the platform default (e.g.
$XDG_CONFIG_HOME/nixon Unix)
Likewise for the state and cache directories.
Miscellaneous environment variables
-
Indicator that tells if the current environment was set up by
nix-shell. It can have the valuespureorimpure.
Appendix: OS-specific conventions
This information is not Nix-specific, but is referenced above.
Unix: XDG Base Directories {#xdg-base-directories}
The XDG Base Directory Specification defines standard locations for user-specific configuration, state, and cache files on Unix systems.
The following environment variables are used:
- [
XDG_CONFIG_HOME]{#env-XDG_CONFIG_HOME} (default~/.config) - [
XDG_STATE_HOME]{#env-XDG_STATE_HOME} (default~/.local/state) - [
XDG_CACHE_HOME]{#env-XDG_CACHE_HOME} (default~/.cache) - [
XDG_CONFIG_DIRS]{#env-XDG_CONFIG_DIRS} (default/etc/xdg) — colon-separated list of additional configuration base directories, searched afterXDG_CONFIG_HOME
Windows: Known Folders {#known-folders}
On Windows, Known Folders provide standard locations for application data on Windows.
The relevant folders are:
- [
%APPDATA%]{#env-APPDATA} — per-user roaming application data - [
%LOCALAPPDATA%]{#env-LOCALAPPDATA} — per-user local application data - [
%PROGRAMDATA%]{#env-PROGRAMDATA} — system-wide application data