无法在 NixOS 中执行二进制文件 - 没有这样的文件或目录

mic*_*has 14 linux dynamic-linking binary nixos patchelf

我尝试在运行 NixOS 的 VM 上安装当前的 oracle jre。

现在发生以下情况:

[michas@cc:~]$ tar xvzf jre-7u40-linux-x64.tar.gz |grep bin/java
jre1.7.0_40/bin/javaws
jre1.7.0_40/bin/java_vm
jre1.7.0_40/bin/java

[michas@cc:~]$ ls -l ./jre1.7.0_40/bin/java
-rwxr-xr-x 1 michas nogroup 7750 Aug 27 09:17 ./jre1.7.0_40/bin/java

[michas@cc:~]$ ./jre1.7.0_40/bin/java
bash: ./jre1.7.0_40/bin/java: No such file or directory
Run Code Online (Sandbox Code Playgroud)

跆拳道?命名文件显然在那里。到底是怎么回事?

尝试进一步分析:

[michas@cc:~]$ strace ./jre1.7.0_40/bin/java
execve("./jre1.7.0_40/bin/java", ["./jre1.7.0_40/bin/java"], [/* 53 vars */]) = -1 ENOENT (No such file or directory)
write(2, "strace: exec: No such file or di"..., 40strace: exec: No such file or directory
) = 40
exit_group(1)                           = ?
+++ exited with 1 +++

[michas@cc:~]$ strace ./jre1.7.0_40/bin/jav
strace: Can't stat './jre1.7.0_40/bin/jav': No such file or directory
Run Code Online (Sandbox Code Playgroud)

好的,一个真正丢失的文件的输出看起来不同。

[michas@cc:~]$ file ./jre1.7.0_40/bin/java
./jre1.7.0_40/bin/java: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.9, BuildID[sha1]=a558f547fe0b95fdc6a109cb7d9692d6d7969794, not stripped

[michas@cc:~]$ file ~/t
/home/michas/t: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, not stripped
Run Code Online (Sandbox Code Playgroud)

后者是一个很小的自编译二进制文件,运行没有问题。两者看起来非常相似。因此格式化二进制文件本身似乎没问题。

[michas@cc:~]$ ldd ./jre1.7.0_40/bin/java
/run/current-system/sw/bin/ldd: line 116: ./jre1.7.0_40/bin/java: No such file or directory
Run Code Online (Sandbox Code Playgroud)

似乎需要的共享库存在问题。

这是怎么回事,我该如何解决?

小智 11

您通常不能在 NixOS 中运行二进制文件,它们需要设置一些环境变量或使用 patchElf 进行修补。我假设您可以使用 nix 包管理器安装和运行 java。您也可以使用 myEnvFun 创建一个合适的环境来运行它。

  • 也许,[一个例子](http://unix.stackexchange.com/a/190736/4319) 使用 `patchelf` 在 nix 环境中运行二进制文件可能对那些搜索解决方案的人有用。但是这种情况是在 CentOS 下的单用户 nix 安装中用户的“活动”nix 环境,您的需求可能会有所不同(IIC 更棘手的方法不是指“活动”符号链接环境,而是指特定的版本化,在 nix 商店中散列一个)。 (2认同)