不存在该文件

不存在该文件

这怎么可能?

bash: /usr/local/phantomjs/bin/phantomjs: No such file or directory
bash-4.3# cd /usr/local/phantomjs/bin
bash-4.3# ls
phantomjs
bash-4.3#

的内容/usr/local/phantomjs/binphantomjs文件,但是当我尝试执行它时,它看起来好像不存在。

仅供参考,我使用的是 Alpine Linux 3.3

更新1

bash-4.3# ls -lF /usr/local/phantomjs/bin/phantomjs
-rwxr-xr-x    1 root     root      67932064 Jan 25  2016 /usr/local/phantomjs/bin/phantomjs*
bash-4.3# lf -lF /usr/local/phantomjs/bin
bash: lf: command not found
bash-4.3# ls -lF /usr/local/phantomjs/bin
total 66340
-rwxr-xr-x    1 root     root      67932064 Jan 25  2016 phantomjs*

更新2

bash-4.3# file /usr/local/phantomjs/bin/phantomjs
bash: file: command not found
bash-4.3# head -n1 /usr/local/phantomjs/bin/phantomjs
ELF>xvA@`�
Q�t/lib64/ld-linux-x86-64.so.2GNUGNU����!�`�L`�L^|��������h�TT@T@DD`��`�L`�P�tddB�dB�dB��g

更新3

bash-4.3# echo $PATH
/usr/local/phantomjs/bin:/usr/local/ruby/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
bash-4.3# ruby -v
ruby 2.1.10p492 (2016-04-01 revision 54464) [x86_64-linux]

更新4

bash-4.3# strace /usr/local/phantomjs/bin/phantomjs
execve("/usr/local/phantomjs/bin/phantomjs", ["/usr/local/phantomjs/bin/phantom"...], [/* 13 vars */]) = -1 ENOENT (No such file or directory)
writev(2, [{"strace: exec: No such file or di"..., 39}, {"\n", 1}], 2strace: exec: No such file or directory
) = 40
writev(2, [{"", 0}, {NULL, 0}], 2)      = 0
getpid()                                = 12
exit_group(1)                           = ?
+++ exited with 1 +++

谢谢

答案1

shell 将报告一个模棱两可的“没有这样的文件或目录当 shell 无法找到可执行文件的依赖项时,会为可执行文件执行“缺少的依赖项”。
缺少的依赖项通常是必需的共享库或动态加载器。

使用斯特拉斯命令来明确查看打开()执行请求期间失败的系统调用(例如strace /usr/local/phantomjs/bin/phantomjs)。

附录

execve("/usr/local/phantomjs/bin/phantomjs", ["/usr/local/phantomjs/bin/phantom"...], [/* 13 vars */]) = -1 ENOENT (No such file or directory)

evecve 系统调用返回错误代码 ENOENT,手册页将其描述为“文件文件名或者脚本或 ELF 解释器不存在,或者找不到文件或解释器所需的共享库。”

通常我发现 strace 能更好地解决丢失的文件问题。
下一步是检查可执行文件的依赖项。
使用字符串命令提取可执行文件开头列出的动态链接器/加载器、共享库和入口点。

strings /usr/local/phantomjs/bin/phantomjs | less

对于每个文件名您可以在此列表中识别,然后您必须验证该文件是否已安装在您的根文件系统中。

$ file modetest
modetest: ELF 32-bit LSB  executable, ARM, EABI5 version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 3.10.0, stripped

$ strings modetest | less
/lib/ld-linux-armhf.so.3    <=
libdrm.so.2    <=
drmModeFreeObjectProperties
drmModeFreePlaneResources
_ITM_deregisterTMCloneTable
 ...
libpthread.so.0    <=
pthread_join
pthread_create
__errno_location
 ...
libc.so.6    <=
strcpy
exit
mmap64
 ...

从之前的 Update2 开始,第一个文件是/lib64/ld-linux-x86-64.so.2


相关内容