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


    举例: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 检验

    仅供参考,内容中会引用部分博友的文章。(侵删)
  • 相关阅读:
    JDBC连接效率问题
    如何配置Filter过滤器处理JSP中文乱码(转)
    Servlet生命周期与工作原理(转)
    ANR触发原理
    SystemServer概述
    Zygote总结
    ART、JIT、AOT、Dalvik之间有什么关系?
    谈谈android缓存文件
    Activity启动过程全解析
    tombstone问题分析
  • 原文地址:https://www.cnblogs.com/zeran/p/15704937.html
Copyright © 2020-2023  润新知