--group-start/--group-end 能不能解决 OpenSSL 1.0 vs 1.1 的优先级问题?

--group-start / --group-end 其实是 ld 链接器的一个功能,专门用来解决 循环依赖的静态库 问题。

例如:

cpp 复制代码
-Wl,--start-group -lfoo -lbar -lbaz -Wl,--end-group

会让链接器在这几个库之间反复扫描,直到符号解析完为止。


🔎 那么能不能用它来"优先选 1.0 而不是 1.1"?

答案是:不行,原因如下:

  1. --start-group/--end-group 只是解决静态库依赖次序的问题,不会影响动态库选择优先级。

    • 它能帮你在 libA.a 依赖 libB.a,而 libB.a 又依赖 libA.a 这种场景下成功链接。

    • 但是它不会改变 libssl.so 版本选择。

  2. 动态库(.so)的版本选择规则是:

    • 链接时:按 -L 搜索路径的顺序找到的第一个匹配 -lssl 的库。

    • 运行时:由 RPATH/RUNPATH + LD_LIBRARY_PATH + 系统默认搜索路径 决定。

    • 这和 group 没关系。

  3. 所以如果你机器上 /usr/liblibssl.so -> libssl.so.1.1,而你想用 libssl.so.1.0.1

    那么即使写成:

    cpp 复制代码
    -Wl,--start-group -L/path/to/ssl101 -lsrosssl101 -L/usr/lib -lssl -Wl,--end-group

    链接器依然可能拉错,因为 .so 是动态符号,最后由 搜索路径顺序 决定。


✅ 正确能保证 1.0 在前的方法

  1. 明确用绝对路径

    cpp 复制代码
    $(OPENSSL101_LIBDIR)/libsrosssl101.so \
    $(OPENSSL101_LIBDIR)/libsroscrypto101.so

    这样就不会被 /usr/lib/libssl.so.1.1 抢走。

  2. 确保 RPATH 先搜 1.0 路径

    复制代码
    cpp 复制代码
    -Wl,-rpath,/usr/lib/openssl101 -Wl,-rpath,/usr/lib

    这样运行时也会先加载 1.0。

  3. shim/dlopen 隔离(我之前建议的方法 3)

    这是彻底避免 1.1 被拖进来的办法。


👉 所以结论:
--group-start/--group-end 不能解决 OpenSSL 1.0 vs 1.1 的优先级问题 ,它只能解决静态库互相依赖的问题。

你要么用 绝对路径 ,要么用 RPATH 控制 ,或者直接上 shim 隔离

相关推荐
柱子子子子44 分钟前
Ubuntu24.04 不能使用todesk 解决办法
运维·服务器
天若有情6731 小时前
新闻通稿 | 软件产业迈入“智能重构”新纪元:自主进化、人机共生与责任挑战并存
服务器·前端·后端·重构·开发·资讯·新闻
BJ_Bonree1 小时前
圆桌论坛精华实录 | AI是重构运维逻辑的颠覆性革命?博睿数据与行业大咖亲授“AI+可观测性”的破局之道
运维·人工智能·重构
鱼干~1 小时前
electron基础
linux·javascript·electron
apocelipes1 小时前
POSIX兼容系统上read和write系统调用的行为总结
linux·c语言·c++·python·golang·linux编程
冬夜戏雪1 小时前
【尚庭公寓152-157】[第6天]【配置阿里云号码认证服务】
运维·服务器
恋上钢琴的虫2 小时前
openEuler上安装高版本的docker
运维·docker·容器
森语林溪2 小时前
大数据环境搭建从零开始(十四)CentOS 7 系统更新源更换详解:阿里云镜像源配置完整指南
大数据·linux·运维·阿里云·centos
Fanmeang2 小时前
华为交换机VLAN技术详解:从基础到高级应用
运维·网络·华为·vlan·交换机·mux vlan
Y淑滢潇潇3 小时前
RHCE Day3 DNS服务器
运维·服务器