Nix 派生中的隔离临时文件

Isolated temporary files in Nix derivation

我没有在 Nix 派生中找到任何关于处理临时文件的信息。

我找到了 $TMP$TMPDIR 环境变量,但它们都指向 /tmp,这是系统全局变量。

{
  pkgs ? import <nixpkgs> {}
}:
  pkgs.stdenv.mkDerivation {
    pname = "show-tmp"
    version = "0.1.0";
    src = ./.;
    configurePhase = ''
      echo "tmp = $tmp; TMP =  $TMP; TMPDIR = $TMPDIR"
    '';
    buildPhase = '':'';
    installPhase = '':'';        
  }

变量 $tmp 没有在 mkDerivation 中定义。我会期待这样的事情,因为其他派生范围变量遵循小写风格,例如 $out.

/tmp 的问题很明显 - 它是全局目录。 我需要担心碰撞和清洁。

我的派生挂钩归档了一个大文件夹树。

如果您在 Linux,请不要担心。 Nix 沙箱将为您的构建提供自己的空 /tmp。推导完成后,它会被删除。

在 macOS 上,$TMP$TMPDIR 得到处理,但 /tmp 是一个潜在问题。

Linux: https://github.com/NixOS/nix/blob/340f831ebe9d74659b84667b96251b7ab0edd09d/src/libstore/build/local-derivation-goal.cc#L609-L614

达尔文:

nix-build --expr 'with import <nixpkgs> {}; runCommand "hi" {} "echo a > /tmp/a; ls -al /tmp; sleep 1;"'
ls -al /private/tmp/
...
-rw-r--r--  1 nixbld1  wheel    2 May 19 12:49 a
...

这是我在 2020 年初安装 Nix 的 macOS 机器上。