- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想发送和归档二进制文件(带库的可执行文件),它们与尽可能多的 Linux 发行版向后和向前兼容,并且整个包可重定位。据我了解系统库,如 libc
还需要发送,因为给定不同版本的 libc
可执行文件会崩溃.同时libc
好像加上ld-linux
(例如,在 Debian 测试中编译的二进制文件已经无法在 Ubuntu 18.04 LTS 上运行),所以我需要打包 ld-linux
也是。
我的解决方案是将所有可执行文件和库放在一个目录中并将 rpath 设置为 $ORIGIN
(通过链接 -Wl,rpath=$ORIGIN
或设置 chrpath
或 patchelf
)。这使得库可以与可执行文件一起重定位,并且适用于除 ld-linux
之外的所有库。这是链接器本身。
可以通过 -Wl,--dynamic-linker=/my/path/ld-linux.so
更改动态链接器路径或者用 patchelf
设置但路径必须是绝对路径:
$ORIGIN
技巧不起作用./
工作,但仅当当前目录与加载程序本身相同时(可执行文件从其他地方启动时因错误而崩溃)/my/path/ld-linux.so /my/path/myexecutable $@
启动可执行文件,但这意味着我想避免的另一层间接和开销。有没有一种方法可以将相对于可执行文件的 ld-linux 路径直接设置为可执行文件?
也许有一种静态链接 ld-linux 加载程序的方法?
最佳答案
As I understand system libraries like libc also need to be shipped because the executable will crash given a different version of libc.
这是不正确的:GLIBC 保证向后兼容性(在旧系统上构建的可执行文件将继续在新版本的 GLIBC 上运行)。
实现您想要的唯一明智的方法是针对您希望支持的 最旧 版本的 GLIBC 进行编译。
Meanwhile libc seems to be coupled with ld-linux
正确:libc.so.6
和 ld-linux
是 GLIBC 的一部分,必须 来自相同的构建,任何不匹配可能导致灾难性故障(SIGSEGV
inside libc.so.6
,或 inside ld-linux
)。
I need to package ld-linux too.
这很复杂:ld-linux
的绝对 路径被硬编码到 a.out
中,并且不能变了。制作一个可重定位 a.out
可以容忍对 ld-linux
路径的更改是不可能的(缺少显式加载程序调用你已经尝试过;这对于重新执行自身的可执行文件来说效果不佳)。
更新:
I could try building on an old Ubuntu LTS and get most of backward compatibility, but then I would not get the new C++17 compilers, which basically defeats the whole point of modern software engineering.
您可以在旧系统上安装更新的编译器,并使用旧的 GLIBC 获取 C++17。
这样做的一个困难是您可能需要更新的 libstdc++.so.6
。
好消息是 -Wl,-rpath=$ORIGIN
工作正常——只有 GLIBC 很难重新定位。您还可以将可执行文件与 --static-libstdc++
链接到 libstdc++.a
。
但是,执行任何一种操作都可能涉及许可问题(但话又说回来,您的计划已经包括分发所有库,因此这个问题并不新鲜)。
关于linux - ld-linux 动态链接器/解释器的相对可执行路径,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54840445/
所以问题是:如何使用标准 C 库以跨平台方式实现简单的自检可执行文件? 在这里,我正在寻找技术,而不是特定的检查方法(如 CRC 或哈希码),但该技术可能包含更适合某些方法的元素(例如见下文)。 目的
我想构建一个 C++ 可执行文件,以便所有库也附加到可执行文件。构建这样一个可执行文件的方法是什么?因此,每当我在其他 PC(运行 Ubuntu)上使用 g++ 编译我的代码时,它不需要运行该可执行文
我在 Netbeans IDE 8.0.1 中编写了一个名为 SampleChat 的 Java GUI 程序,并使用“clean and build”功能创建了一个 jar 文件。 我进入 Netb
我有两个 DLL,一个用 native C++ 编写,另一个用 C++/CLI 编写。前者被注入(inject)到进程中,并在稍后的时间点加载后者。在调试时,我注意到 native DLL 的断点运行
如何访问可执行文件的机器代码(二进制文件)? 详情 我使用的是 Ubuntu (Linux) 我想访问 .exe 文件(文件遵循 PE 格式)的机器代码(二进制文件) 我正在使用 C 来实现 最佳答案
这个问题在这里已经有了答案: Run java jar file on a server as background process (4 个回答) 关闭1年前. 我正在使用命令提示符运行一个可执行
我的 jar 没有运行,我可以告诉它尝试运行,因为 log4j 文件设法创建日志文件夹,但没有任何 react 并且日志为空白。 我的问题是我在名为 bin 的文件夹中有 jar 文件,在名为 lib
我正在为我教育第一学期的编程考试创建一个程序。它应该向用户显示哥本哈根和其他 6 个城市(在其他时区)的时间。用户还应该能够将城市添加到列表中。我正在用 JAVA 编写程序(下面提供源代码)。当我从
我正在查看雅虎的 YUI 压缩器可执行 jar,他们有这个类,从 list 文件链接为“主类”: package com.yahoo.platform.yui.compressor; import j
问题是:从 Eclipse 导出时可执行 jar 中包含什么?我问这个问题是因为我想知道,例如,如果我在项目根目录中有一个图像,该图像是否会包含在导出中? 澄清:我说的是可运行的 jar 文件(已编辑
我知道这个问题已经被问了很多,并且我已经尝试了 eclipse(Kepler、Ganymede、Galileo)、fatJar、netbeans、blueJ、命令行和手册中的大约 20-30 种不同的
我从 IntelliJ 14.03 中的一个工件构建了一个 .jar。当我尝试在 JRE 中打开它时,没有任何反应。这只是一个简单的 GUI。 提前致谢。 最佳答案 在jar位置运行命令,例如 jav
我使用 eclipse 创建了一个可执行 JAR 文件。我在项目文件夹中有资源当框架打开时不会出现。我的意思是当我双击 JAR 文件时。更多的所以,在我尝试删除 JAR 文件后,我收到一条警告,表明该
我创建了一个尺寸相当大(125,000 kb)的可运行 Jar 文件。当我运行它时,该 jar 文件内的应用程序不会显示,但在任务管理器中 javaw.exe(应链接到该 jar 文件)进程正在运行。
我已经使用 Eclipse(文件->导出)为我的 java 程序创建了一个可执行 jar 文件。 当我双击 jar 时,它工作正常。将 jar 文件复制到另一台计算机(Windows)后,我收到错误“
我用 eclipse indigo 创建了一个可执行的 jar 文件,但是当我双击它时什么也没有发生。但是当我将 java -jar c:/dir/filename.jar 写入 cmd 时,它可以工
已关闭。这个问题是 off-topic 。目前不接受答案。 想要改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 已关闭10 年前。 Improve th
如何让该 Java 代码在 Eclipse 之外运行? import java.util.*; public class Calculations { public static void main(
今天我第一次启动 jar 文件时遇到问题。现在我知道(解压 jar 后)当我在 Eclipse 中导出并创建程序的 jar 包时,文本文件并没有出现。 为什么文本文件没有与类文件一起出现?我应该将它们
我不知道为什么,但是当我将项目导出到可执行 jar 文件时,有些东西并不像从 eclipse 运行程序一样。一帧不会打开,其中只包含文本。我有另一个内部框架,它是一个分割 Pane ,包含右侧面板上的
我是一名优秀的程序员,十分优秀!