记一次动态依赖包版本过高解决过程
举例: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 检验