Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Running Nix as root ignores nix-damon's TMPDIR #7154

Open
Atemu opened this issue Oct 10, 2022 · 7 comments
Open

Running Nix as root ignores nix-damon's TMPDIR #7154

Atemu opened this issue Oct 10, 2022 · 7 comments
Labels

Comments

@Atemu
Copy link
Member

Atemu commented Oct 10, 2022

Describe the bug

A clear and concise description of what the bug is.

Nix builds ignore the nix-daemon's TMPDIR environment variable when run as root.

Steps To Reproduce

  1. TMPDIR=/var/tmp nix-daemon
  2. nix-build '<nixpkgs>' -A hello --check
  3. sudo nix-build '<nixpkgs>' -A hello --check

Expected behavior

A clear and concise description of what you expected to happen.

Both builds should run in /var/tmp.

nix-env --version output

nix-env (Nix) 2.11.0

Additional context

Add any other context about the problem here.

This happens all the time when you try to run nixos-rebuild because that command obviously needs to run as root.
The kernel build notably uses more space than most people have space for in /tmp thanks to BTF. sudo nixos-rebuild switch with a custom kernel build is no bueno by default for the vast majority of systems. That's not a good UX.

Honestly, I don't see why /tmp should be the default. Sure, it can be a useful optimisation if you know your builds are all tiny but that's an assumption you cannot make for all builds in general.
/var/tmp is on a physical disk by default and therefore makes a much better default TMPDIR.

@Atemu Atemu added the bug label Oct 10, 2022
@benaryorg
Copy link

Nix builds ignore the nix-daemon's TMPDIR environment variable when run as root.

To add a specific use-case to this; this applies to deployments via colmena as it uses nix-store --realise as root for this.

Honestly, I don't see why /tmp should be the default. Sure, it can be a useful optimisation if you know your builds are all tiny but that's an assumption you cannot make for all builds in general.
/var/tmp is on a physical disk by default and therefore makes a much better default TMPDIR.

To expand on this with a very clear rationale; if nix uses a separate directory I, as a sysadmin, can decide to mount either a tmpfs there, a different disk, a bindmount, whatever.
If nix uses a directory that is shared with other data I do not have the ability to influence this.

Especially considering that setting boot.crashDump.enable will set custom config options and thus compile a fresh Linux kernel, which usually tends to exceed 8GiB in object files (especially during compression phase) this makes it unfeasible to run this in tmpfs on any machine with 16GiB of RAM or less, which I'd estimate is a very good chunk of machines out there.

@Atry
Copy link
Contributor

Atry commented Apr 12, 2023

This issue can result in failures in pkgs.writeShellApplication when running nix build under a dev shell with root user. I created a repository to reproduce the error in https://github.com/Atry/nix-tmpdir-bug-report

Reproducting step

  1. Clone https://github.com/Atry/nix-tmpdir-bug-report.git
  2. Open the work tree in VS Code
  3. Install the Dev Containers extension https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-containers
  4. Reopen it in a Dev Containers
  5. Open a terminal
  6. Run nix develop -c sh -c 'nix build'

Now you can see the following error:

error: builder for '/nix/store/29z9iy6zx9dvmh075dza7f7zhkmnvx2n-my-app.sh.drv' failed with exit code 1;
       last 2 log lines:
       > unpacking sources
       > variable $src or $srcs should point to the source
       For full logs, run 'nix log /nix/store/29z9iy6zx9dvmh075dza7f7zhkmnvx2n-my-app.sh.drv'.

Workarounds

Workaround 1: removing "remoteUser": "root", from the dev container configuration

https://github.com/Atry/nix-tmpdir-bug-report/blob/310e5f5e57b347d9e1ec0915aa1187bb063218c9/.devcontainer/devcontainer.json#L15

Workaround 2: unset TMPDIR

Run nix develop -c sh -c 'unset TMPDIR && nix build', then the build would succeed.

Workaround 3: Don't use nix develop

Directly run nix build, then the build would succeed.

@doronbehar
Copy link
Contributor

This issue is very annoying - I ran into it now when performing a nixos-rebuild as root, and I have in my nixos config:

    boot.tmp.useTmpfs = true;
    # Use a tmpdir with unlimited space (as opposed to /tmp)
    systemd.services."nix-daemon".environment.TMPDIR = "/nix/tmp";
    systemd.tmpfiles.rules = [
      "d /nix/tmp 770 root nixbld"
    ];

@obj-obj
Copy link

obj-obj commented Sep 23, 2023

if you run sudo env TMPDIR=/nix/tmp nixos-rebuild switch, it will use the correct tmpdir. Maybe just alias that for now?

@Quant-ux
Copy link

Quant-ux commented Dec 23, 2023

I primarily interact with the nix-daemon via nixos-rebuild and have used the alias workaround with success.

As of 23.11, the workaround no longer works because of NixOS/nixpkgs#258571 unless NIXOS_SWITCH_USE_DIRTY_ENV is set; however, it is going to be removed in the future[1].

As it stands, to my knowledge, there is no future-proof, working workaround that applies to my use case.
1. NixOS/nixpkgs#258977

My issue was caused by a bad sudo configuration and after fixing it, the alias workaround works for me again.

@thufschmitt
Copy link
Member

This is likely related to #10140: Running Nix as root will bypass the daemon altogether.
Workaround: use NIX_REMOTE=daemon (or set store = daemon in your Nix config, and pass --store local to the daemon invocation in the systemd unit)

@benaryorg
Copy link

Note that Nix ≥2.22 (as well as Lix ≥2.91) have the new build-dir nix.conf setting.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

7 participants