3

我正在尝试 CX_Freeze Linux 平台的应用程序。Windows MSI 安装程序运行良好,但 Linux 对应部分并没有真正按照我想要的方式运行。

构建包时,它可以在原始系统上完美运行,但是当移植到不同的系统(尽管架构相同)时,它会生成段错误。我做的第一件事是检查库,libc、pthread 和 libdl 存在一些巨大的版本差异。所以我决定将这些包含在构建中,如下所示:

if windows_build:
    build_exe_options['packages'].append("win32net")
    build_exe_options['packages'].append("win32security")
    build_exe_options['packages'].append("win32con")
    pywintypes_dll = 'pywintypes{0}{1}.dll'.format(*sys.version_info[0:2])      # e.g. pywintypes27.dll
    build_exe_options['include_files'].append((os.path.join(GetSystemDirectory(), pywintypes_dll), pywintypes_dll))
else:
    build_exe_options['packages'].append("subprocess")
    build_exe_options['packages'].append("encodings")
    arch_lib_path = ("/lib/%s-linux-gnu" % os.uname()[4])
    shared_objects = ["libc.so.6", "libpthread.so.0", "libz.so.1", "libdl.so.2", "libutil.so.1", "libm.so.6", "libgcc_s.so.1", "ld-linux-x86-64.so.2"]
    lib_paths = ["/lib", arch_lib_path, "/lib64"]
    for so in shared_objects:
        for lib in lib_paths:
            lib_path = "%s/%s" % (lib, so)
            if os.path.isfile(lib_path):
                build_exe_options['include_files'].append((lib_path, so))
                break

在检查了原始的 cx_frozen bin 之后,动态库似乎在那里发挥了作用并完美地拦截了调用。尽管现在我处于 pthread 段错误的位置,因为他尝试了系统 libc 而不是我的(使用 ldd 和 gdb 检查)。

我的问题很简单,我正在尝试的这种方法很糟糕,因为它不能解决递归依赖问题。因此我的问题是“这样做的更好方法是什么?或者我应该在我的安装程序中编写递归依赖解决方案?”

为了击败解决方案:“改用本机 Python”,我们有一些硬件设备(想想 2~4U)和 Linux(和 Bash 访问),我们也想在其中运行它。当我们可以 cx_freeze 并将其与库一起发布时,移植整个 python(及其动态链接等)似乎是一种很有效的方法。

4

1 回答 1

2

我不知道您的其他问题,但是libc.so.6按照您的方式将其运送到另一个系统是不可能的,如此所述。

于 2013-05-06T03:37:54.073 回答