记一次动态依赖包版本过高解决过程

举例:xxx.so 包依赖了openssl的libssl.so 和 libcrypto.so 包,

由于openssl版本为1.1.1k 已经取消了一些接口函数,尝试低版本后发现openssl-1.0.2j.tar.gz包含这些接口函数。

另外xxx.so为动态包,是不能将openssl-1.0.2j.tar.gz 编译后libssl.a 这种方法引用的

首先检验缺少那些依赖包:

ldd t2sdk.so 

 

 not found 表示找不到依赖包,

由于之前安装过openssl-1.1.1k版本,所以可以直接对依赖的两个包进行软链接。

 

ln -s /usr/lib64/libssl.so.1.1 /usr/lib64/libssl.so
ln -s /usr/lib64/libcrypto.so.1.1 /usr/lib64/libcrypto.so 

使用ln 命令进行软连接建立,libcrypto.so.1.1 是原有文件,libcrypto.so 是软连接名称。libcrypto.so 是ldd命令后看到缺少的包名,如果缺少 libnsl.so.1则命令就是

ln -s /usr/lib64/libnsl.so.2 /usr/lib64/libnsl.so.1

此时可以正常编译了。

==============================以下为尝试安装低版本操作,对实际的代码编译好像没起到作用================================================

所以需要先卸载openssl包,再安装1.0.2j版本(如果可以的话,可以在c++代码中使用xxx.a静态包,依赖包也是静态包就可以了)

谨慎使用yum remove openssl

由于yum remove 会卸载和openssl相关的包,可能会导致其他错误。建议使用rpm -e --nodeps <包名>命令卸载

#-e :卸载软件

[root@blog source]# rpm -e openssl

删除一个rpm包时忽略依赖关系

 #--nodeps: 忽略依赖关系强制卸载

[root@blog source]# rpm -e --nodeps openssl

然后下载openssl-1.0.2j.tar.gz

tar -zxvf openssl-1.0.2j.tar.gz

./config ----prefix=/usr/local

make && make install

安装完毕使用 openssl version 检验

 

posted @ 2021-12-18 14:09  zeran  阅读(931)  评论(0编辑  收藏  举报