Ubuntu可执行文件存在但是无法执行
2018-08-25 本文已影响2303人
胡涂笔记
本文先写的是发现问题的步骤,如果不关心过程,可直接跳到文末。
可执行文件存在但是不能执行,一般都是报错No such file or directory
,但是形式可能有很多种:
- 系统函数调用某个可执行文件,但是这个可执行文件无法执行,然后报错,比如:
posix_spawn failed: No such file or directory
- 在bash中直接执行的一个可执行文件,也有文件不存在的提示:
clang: error: no such file or directory
这个时候我们可能就会通过ls
命令来确定这个文件到底是不是真的存在,当看到ls
看到文件存在时,很可能就放松了警惕。出现问题需要仔细辨别问题的root cause,可能有很多表面的报错,一定要弄清楚,到底是执行什么操作的时候程序挂了。
对于可执行文件明明存在,但是无法执行,笔者遇到的情况都是在64位系统上,出问题的可执行文件是32位的,比如:
# file xxx
xxx: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux.so.2, for GNU/Linux 2.2.5, stripped
通过file
命令可以看到这个可执行程序的位数,通过ldd
可以查看这个可执行文件需要的动态链接库,比如:
# ldd xxx
linux-gate.so.1 (0xf7f44000)
libc.so.6 => /lib/i386-linux-gnu/libc.so.6 (0xf7d4b000)
/lib/ld-linux.so.2 (0xf7f46000)
这个时候,如果这个文件却是存在,但是不能执行,而文件又没有损坏,那很可能就是因为依赖的动态库不存在,一般是这个:
/lib/ld-linux.so.2
有这个库才能在64位的系统上执行32位的程序,所以根据你的系统,把这个库安装上即可。命令就是:
sudo dpkg --add-architecture i386
sudo apt install libc6:i386
笔者在ubuntu下进行研发工作,经常用一些嵌入式的编译器,又比较喜欢新的系统(ubuntu14.04到18.04),经常折腾,半年内遇到了两次,但这并不是折腾和系统的锅。
大家如果有遇到其他的情形,欢迎留言探讨,共同进步!