Linux发行版之间的二进制兼容性

对不起,如果这是一个显而易见的问题,但我发现很少有人在网上引用…

我正在使用我们的业务合作伙伴用C编写的API,并将其作为.so二进制文件提供给我们,构建在Fedora 11上.我们已经在Fedora 11开发机器上测试了API,没有任何问题.但是,当我尝试链接客户目标平台上的API(恰好是SuSE Enterprise 10.2)时,我收到“文件格式无法识别”错误.

同样属于binutils包的命令,例如objdump或nm,给出了相同的文件格式错误. “file”命令显示我:

ELF 64-bit LSB shared object,AMD x86-64,version 1 (SYSV),not stripped

并且“ldd”命令显示

ldd: warning: you do not have execution permission for `./libuscuavactivity.so.1.1'
./libuscuavactivity.so.1.1: /usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.9' not found (required by ./libuscuavactivity.so.1.1)
[dependent library list]

我猜这是由于两个平台上的C库之间不兼容,问题是代码是针对新版本的glibc等而不是SuSE 10.2上提供的.我发布这个问题是因为有一种方法可以在我们的合作伙伴的Fedora 11平台上编译代码,这样它也可以在SuSE 10.2上运行.

解决方法

我认为诀窍在于使用您希望支持的任何平台的最旧内核和C库版本来构建Linux的风格.在我的工作中,我们以Debian 4为基础,允许我们以非官方方式正式支持Debian 4及以上版本,RedHat 3,4,5,SuSE 10以及其他各种发行版(SELinux等).

我怀疑通过构建一个不错的新版本的Linux,很难支持旧机器上的人.

(编辑)我应该提一下,我们使用Debian 4附带的认编译器,我认为是GCC 4.1.2.安装较新的编译器版本往往会使兼容性更差.

相关文章

在Linux上编写运行C语言程序,经常会遇到程序崩溃、卡死等异...
git使用小结很多人可能和我一样,起初对git是一无所知的。我...
1. 操作系统环境、安装包准备 宿主机:Max OSX 10.10.5 虚拟...
因为业务系统需求,需要对web服务作nginx代理,在不断的尝试...
Linux模块机制浅析 Linux允许用户通过插入模块,实现干预内核...
一、Hadoop HA的Web页面访问 Hadoop开启HA后,会同时存在两个...