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


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

    仅供参考,内容中会引用部分博友的文章。(侵删)
  • 相关阅读:
    【算法】剑指第二版面试题6 :从尾到头打印链表
    Go电商秒杀 (1)
    Go秒杀服务端优化
    Linux AUFS 文件系统
    mount挂载虚拟文件系统
    自己动手写docker之Linux命令(CentOS7.7)
    自己动手写docker之namespace和cgroup
    【协作式原创】自己动手写docker之urfave cli
    Go 1.14之前的死循环Case
    linux下定时执行任务的方法
  • 原文地址:https://www.cnblogs.com/zeran/p/15704937.html
Copyright © 2020-2023  润新知