linux - 为什么在尝试运行此可执行文件时出现错误?

标签 linux cx-freeze nuitka

我正在尝试将 python 3 应用程序部署到具有 armv7 架构的嵌入式 linux (Yocto) 机器。由于软件包有限,我在我的树莓派(具有相同的 armv7 架构)上使用 cx-freeze 创建了一个独立文件。现在,如果我尝试在目标机器上运行创建的二进制文件,我会收到一条错误消息,表明源代码是为另一个平台编译的:

root@target:/media/sda/dist# ./helloworld
-sh: ./helloworld: No such file or directory

此可执行文件可在构建机器上运行。

我将文件命令的输出与目标机器上运行的另一个应用程序进行了比较:

这是工作的文件:

root@target:/media/sda/dist# file helloworld
helloworld: ELF 32-bit LSB executable, ARM, EABI5 version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.26, BuildID[sha1]=99b2ae19f1e65dc26b6fd7d8b1dbc83f974830bd, stripped

这是在目标机器上确实工作的另一个二进制文件:

root@target:/usr/bin# file demo-application
demo-application: ELF 32-bit LSB executable, ARM, EABI5 version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.16, BuildID[sha1]=bd6660c43d9e98c59dfa8b16eb26277aa4f19949, stripped

唯一的区别似乎是所需的最低内核版本,但 uname 显示实际版本是 3.0.35:

root@target:/media/sda/dist# uname -a
Linux Target-Machine 3.0.35-Yocto-21.0-r5061-0-svn2437 #1 PREEMPT Fri Jun 19 21:40:10 CEST 2015 armv7l GNU/Linux

树莓派构建机器的 uname 输出:

pi@raspberrypi ~/py/helloworld $ uname -a
Linux raspberrypi 3.18.11-v7+ #781 SMP PREEMPT Tue Apr 21 18:07:59 BST 2015 armv7l GNU/Linux

我在这里做错了什么?它不应该是实际的 python 代码或依赖项的问题,我用一行代码用一个非常简单的 helloworld 应用程序尝试了它。

编辑

构建机器上 ldd 命令的输出(使用 nuitka 创建的 exe):

pi@raspberrypi ~/py/helloworld/helloworld.dist $ ldd helloworld.exe
    /usr/lib/arm-linux-gnueabihf/libcofi_rpi.so (0x76faf000)
    libdl.so.2 => /home/pi/py/helloworld/helloworld.dist/./libdl.so.2 (0x76fa4000)
    libpython3.2mu.so.1.0 => /home/pi/py/helloworld/helloworld.dist/./libpython3.2mu.so.1.0 (0x76ccf000)
    libstdc++.so.6 => /home/pi/py/helloworld/helloworld.dist/./libstdc++.so.6 (0x76bfd000)
    libm.so.6 => /home/pi/py/helloworld/helloworld.dist/./libm.so.6 (0x76b8c000)
    libgcc_s.so.1 => /home/pi/py/helloworld/helloworld.dist/./libgcc_s.so.1 (0x76b64000)
    libc.so.6 => /home/pi/py/helloworld/helloworld.dist/./libc.so.6 (0x76a33000)
    /lib/ld-linux-armhf.so.3 (0x76fbc000)
    libz.so.1 => /home/pi/py/helloworld/helloworld.dist/./libz.so.1 (0x76a15000)
    libexpat.so.1 => /home/pi/py/helloworld/helloworld.dist/./libexpat.so.1 (0x769ec000)
    libpthread.so.0 => /home/pi/py/helloworld/helloworld.dist/./libpthread.so.0 (0x769cd000)
    libutil.so.1 => /home/pi/py/helloworld/helloworld.dist/./libutil.so.1 (0x769c2000)

编辑 2

我尝试使用 nuitka 来编译 python 代码并创建一个独立的应用程序:

nuitka --standalone --recurse-all helloworld.py

它会生成一个可执行的 helloworld.exe 文件以及所有已编译的库文件 (.so)。 然而,在目标机器上,当我尝试运行它时,我仍然得到:

root@target:~/helloworld/helloworld.dist# ./helloworld.exe -sh: ./helloworld.exe: 没有那个文件或目录

不幸的是,我无法在目标机器上运行 lddreadelf 命令,因为它们的包丢失了。

编辑 3

看来它确实缺少一些库。出于实验目的,我将 ld-linux-armhf.so.3 从 raspi 复制到嵌入式系统,它显示了不同的错误(另一个库丢失)。我认为另一个问题是树莓派使用 hardfloat (armhf),而嵌入式系统使用 softfloat。我不认为我可以通过这种方式让它工作。

编辑 4 我现在正在使用另一个平台和操作系统,一切正常,所以这个问题与我不再相关。

最佳答案

在你的目标机器上运行这个命令:

chmod +x helloworld

它使您的文件可执行。

关于linux - 为什么在尝试运行此可执行文件时出现错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32187744/

相关文章:

Linux from scratch error v7.1 ch6.9 Glibc

python - cx_freeze 模块依赖

python - 如何在 Windows 上制作单文件可执行 python 2.7 x64?

使用 Nuitka 进行 Python 独立编译

linux - BASH脚本中的for循环问题

linux - slackbuild chromium 包需要多长时间?

python - 在 Windows 10 上使用 Nuitka 将 Python 3.6 脚本编译为独立的 exe

python - 如何使用 nuitka 共享对象文件?

linux - 获取时区日期命令行linux

python - cx_Freeze 缺少模块