美文网首页Ubuntu
Ubuntu可执行文件存在但是无法执行

Ubuntu可执行文件存在但是无法执行

作者: 胡涂笔记 | 来源:发表于2018-08-25 17:21 被阅读2303次

    本文先写的是发现问题的步骤,如果不关心过程,可直接跳到文末。

    可执行文件存在但是不能执行,一般都是报错No such file or directory,但是形式可能有很多种:

    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
    

    笔者在ubuntu下进行研发工作,经常用一些嵌入式的编译器,又比较喜欢新的系统(ubuntu14.04到18.04),经常折腾,半年内遇到了两次,但这并不是折腾和系统的锅。

    大家如果有遇到其他的情形,欢迎留言探讨,共同进步!

    相关文章

      网友评论

        本文标题:Ubuntu可执行文件存在但是无法执行

        本文链接:https://www.haomeiwen.com/subject/jwugiftx.html