Warning
This program is experimental and its interface is subject to change.
Name
nix build - build a derivation or fetch a store path
Synopsis
nix build [option...] installables...
Note: this command's interface is based heavily around installables, which you may want to read about first (nix --help).
Examples
- 
Build the default package from the flake in the current directory: # nix build
- 
Build and run GNU Hello from the nixpkgsflake:# nix build nixpkgs#hello # ./result/bin/hello Hello, world!
- 
Build GNU Hello and Cowsay, leaving two result symlinks: # nix build nixpkgs#hello nixpkgs#cowsay # ls -l result* lrwxrwxrwx 1 … result -> /nix/store/v5sv61sszx301i0x6xysaqzla09nksnd-hello-2.10 lrwxrwxrwx 1 … result-1 -> /nix/store/rkfrm0z6x6jmi7d3gsmma4j53h15mg33-cowsay-3.03+dfsg2
- 
Build GNU Hello and print the resulting store path. # nix build nixpkgs#hello --print-out-paths /nix/store/v5sv61sszx301i0x6xysaqzla09nksnd-hello-2.10
- 
Build a specific output: # nix build nixpkgs#glibc.dev # ls -ld ./result-dev lrwxrwxrwx 1 … ./result-dev -> /nix/store/dkm3gwl0xrx0wrw6zi5x3px3lpgjhlw4-glibc-2.32-dev
- 
Build attribute build.x86_64-linuxfrom (non-flake) Nix expressionrelease.nix:# nix build --file release.nix build.x86_64-linux
- 
Build a NixOS system configuration from a flake, and make a profile point to the result: # nix build --profile /nix/var/nix/profiles/system \ ~/my-configurations#nixosConfigurations.machine.config.system.build.toplevel(This is essentially what nixos-rebuilddoes.)
- 
Build an expression specified on the command line: # nix build --impure --expr \ 'with import <nixpkgs> {}; runCommand "foo" { buildInputs = [ hello ]; } "hello > $out"' # cat ./result Hello, world!Note that --impureis needed because we're using<nixpkgs>, which relies on the$NIX_PATHenvironment variable.
- 
Fetch a store path from the configured substituters, if it doesn't already exist: # nix build /nix/store/rkfrm0z6x6jmi7d3gsmma4j53h15mg33-cowsay-3.03+dfsg2
Description
nix build builds the specified installables. Installables that
resolve to derivations are built (or substituted if possible). Store
path installables are substituted.
Unless --no-link is specified, after a successful build, it creates
symlinks to the store paths of the installables. These symlinks have
the prefix ./result by default; this can be overridden using the
--out-link option. Each symlink has a suffix -<N>-<outname>, where
N is the index of the installable (with the left-most installable
having index 0), and outname is the symbolic derivation output name
(e.g. bin, dev or lib). -<N> is omitted if N = 0, and
-<outname> is omitted if outname = out (denoting the default
output).
Options
- 
--dry-runShow what this command would do without doing it.
- 
--jsonProduce output in JSON format, suitable for consumption by another program.
- 
--no-linkDo not create symlinks to the build results.
- 
--out-link/-opath Use path as prefix for the symlinks to the build results. It defaults toresult.
- 
--print-out-pathsPrint the resulting output paths
- 
--profilepath The profile to operate on.
- 
--rebuildRebuild an already built package and compare the result to the existing store paths.
- 
--stdinRead installables from the standard input. No default installable applied.
Common evaluation options:
- 
--argname expr Pass the value expr as the argument name to Nix functions.
- 
--argstrname string Pass the string string as the argument name to Nix functions.
- 
--debuggerStart an interactive environment if evaluation fails.
- 
--eval-storestore-url The URL of the Nix store to use for evaluation, i.e. to store derivations (.drvfiles) and inputs referenced by them.
- 
--impureAllow access to mutable paths and repositories.
- 
--include/-Ipath Add path to the Nix search path. The Nix search path is initialized from the colon-separatedNIX_PATHenvironment variable, and is used to look up the location of Nix expressions using paths enclosed in angle brackets (i.e.,<nixpkgs>).For instance, passing -I /home/eelco/Dev -I /etc/nixoswill cause Lix to look for paths relative to /home/eelco/Devand/etc/nixos, in that order. This is equivalent to setting theNIX_PATHenvironment variable to/home/eelco/Dev:/etc/nixosIt is also possible to match paths against a prefix. For example, passing -I nixpkgs=/home/eelco/Dev/nixpkgs-branch -I /etc/nixoswill cause Lix to search for <nixpkgs/path>in/home/eelco/Dev/nixpkgs-branch/pathand/etc/nixos/nixpkgs/path.If a path in the Nix search path starts with http://orhttps://, it is interpreted as the URL of a tarball that will be downloaded and unpacked to a temporary location. The tarball must consist of a single top-level directory. For example, passing-I nixpkgs=https://github.com/NixOS/nixpkgs/archive/master.tar.gztells Lix to download and use the current contents of the masterbranch in thenixpkgsrepository.The URLs of the tarballs from the official nixos.orgchannels (see the manual page fornix-channel) can be abbreviated aschannel:<channel-name>. For instance, the following two flags are equivalent:-I nixpkgs=channel:nixos-21.05 -I nixpkgs=https://nixos.org/channels/nixos-21.05/nixexprs.tar.xzYou can also fetch source trees using flake URLs and add them to the search path. For instance, -I nixpkgs=flake:nixpkgsspecifies that the prefix nixpkgsshall refer to the source tree downloaded from thenixpkgsentry in the flake registry. Similarly,-I nixpkgs=flake:github:NixOS/nixpkgs/nixos-22.05makes <nixpkgs>refer to a particular branch of theNixOS/nixpkgsrepository on GitHub.
- 
--override-flakeoriginal-ref resolved-ref Override the flake registries, redirecting original-ref to resolved-ref.
Common flake-related options:
- 
--commit-lock-fileCommit changes to the flake's lock file.
- 
--inputs-fromflake-url Use the inputs of the specified flake as registry entries.
- 
--no-registriesDon't allow lookups in the flake registries. This option is deprecated; use--no-use-registries.
- 
--no-update-lock-fileDo not allow any updates to the flake's lock file.
- 
--no-write-lock-fileDo not write the flake's newly generated lock file.
- 
--output-lock-fileflake-lock-path Write the given lock file instead offlake.lockwithin the top-level flake.
- 
--override-inputinput-path flake-url Override a specific flake input (e.g.dwarffs/nixpkgs). This implies--no-write-lock-file.
- 
--reference-lock-fileflake-lock-path Read the given lock file instead offlake.lockwithin the top-level flake.
Logging-related options:
- 
--debugSet the logging verbosity level to 'debug'.
- 
--log-formatformat Set the format of log output; one ofraw,internal-json,bar,bar-with-logs,multilineormultiline-with-logs.
- 
--print-build-logs/-LPrint full build logs on standard error.
- 
--quietDecrease the logging verbosity level.
- 
--verbose/-vIncrease the logging verbosity level.
Miscellaneous global options:
- 
--helpShow usage information.
- 
--offlineDisable substituters and consider all previously downloaded files up-to-date.
- 
--optionname value Set the Lix configuration setting name to value (overridingnix.conf).
- 
--refreshConsider all previously downloaded files out-of-date.
- 
--repairDuring evaluation, rewrite missing or corrupted files in the Nix store. During building, rebuild missing or corrupted store paths.
- 
--versionShow version information.
Options that change the interpretation of installables:
- 
--expr/-Eexpr Interpret installables as attribute paths relative to the Nix expression expr.
- 
--file/-ffile Interpret installables as attribute paths relative to the Nix expression stored in file. If file is the character -, then a Nix expression will be read from standard input. Implies--impure.
Note
See
man nix.conffor overriding configuration settings with command line flags.