云网牛站
所在位置:首页 > Linux教程 > 在Ubuntu系统中可执行文件存在但是无法执行的解决方法

在Ubuntu系统中可执行文件存在但是无法执行的解决方法

2018-08-25 20:47:50作者:胡涂笔记稿源:linux站

在Ubuntu系统下进行开发工作,经常用到一些嵌入式的编译器,而会碰到可执行文件存在但是无法执行的情况,从Ubuntu 14.04到Ubuntu 18.04都有出现这种情况,现在把相关的解决方法同大家分享。

 

可执行文件存在但是不能执行,现象可能有很多种情况,比如下面两种。

 

1.系统函数调用某个可执行文件,但是这个可执行文件无法执行,然后报错,比如:

posix_spawn failed: No such file or directory 

 

2.在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

也请参考类似情况的解决32位汇编程序在64位Ubuntu 18.04系统上的汇编和连接一文。

 

相关主题

Linux如何利用可执行文件SUID提权

精选文章
热门文章