AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / user-386025

Stefan Scherfke's questions

Martin Hope
Stefan Scherfke
Asked: 2022-04-26 03:29:21 +0800 CST

现有的 .so 文件即使存在也无法加载,似乎取决于 Docker 主机操作系统

  • 2

我在基于 Alma8 的 Docker 容器中构建了 Qt6,Docker 主机是 Fedora 35。

在某些情况下(如下所述),所有 Qt 库都无法加载libQt6Core.so[.6[.2.4]]. 但是该文件存在并且在正确的目录中搜索该文件。libQt6Dbus.so找到并加载其他 Qt 库(例如)。

广泛的调试、重建、搜索网络并没有产生任何线索,根本原因是什么以及我如何解决它。

定位问题

我已将问题缩小到以下情况:

  • 我创建了两个最小的虚拟机,一个使用 centos7,一个使用 alma8。
  • 我从官方仓库安装了 Docker 到他们两个中。
  • 我在两个 VM 中运行了相同的 Docker 映像并安装了相同的 qt6 包。
  • 当 Docker 主机是 centos7 时它会中断。
  • 它在 Docker 主机为 alma8 时工作。

理论与问题

  • Qt6 是在 Alma8 上构建的,并且链接到一些比 Centos7 提供的更新的系统库,因此 Qt6 不能在 Centos7 下运行(这是完全可以预料的,也可以)。但它应该在 Alma8 Docker 容器中的任何位置运行。
  • 容器镜像应该能够在任何地方运行,但在这种情况下,来自主机操作系统的“某些东西”会潜入容器并导致问题——即使两个容器使用完全相同的镜像!

问题是:这是什么“东西”以及它如何/为什么会破坏构建?

我试过的

我检查libQt6Gui.so了它是否可以加载libQt6Core.so,我检查libQt6Core.so了是否有东西看起来是假的:

  • ldd并且LD_DEBUG=libs ldd确实显示出一些差异(见下文)
  • libtree没有显示出任何差异(但是一棵很好的树:))
  • pyldd(来自 conda-build)
  • readelf -d

我也尝试过:

  • 设置LD_LIBRARY_PATH(没有改变任何东西——这并不奇怪,因为我知道总是搜索正确的路径)
  • 在带有 centos7 主机的 alma8 容器中构建 Qt6(构建失败并显示“ libQt6Core.so.6:无法打开文件”,与构建的库相同的错误)
  • 在 centos7 容器中构建 Qt6(由于我还无法修复的其他问题,构建失败)

区别于ldd

在下面的屏幕截图中,您可以看到左侧Centos7 主机上的 Alma8-Docker-Container 和 *右侧 Alma8 主机上的 Alma8-Docker-Container。

前两张图片显示了ldd /opt/emsconda/lib/libQt6Gui.so. libQt6Core在左边找不到,但在右边找到。

在此处输入图像描述

第二个屏幕截图显示找到并加载了其他 Qt库。左侧的 ICU 库也丢失了——也许它们只在 libQt6Core 也被加载时才被加载?

在此处输入图像描述

此屏幕截图显示了LD_DEBUG=libs ldd .... 您可以看到,在这两种情况下,libQt6Core都是在正确的位置搜索 ( /opt/emsconda/lib)。但它只装载在正确的容器中。左边的另外一个在 `/opt/emsconda/lib/./ (haha)) 中查找,然后默默地走到下一个 lib ...

我找不到任何错误消息。这个文件只是没有打开/加载。

在此处输入图像描述

检查它libQt6Core.so本身可能会给我们一个线索。它链接到一个linux-vdso.so.1.

根据这个 SO question,该文件是操作系统内核注入用户空间的虚拟库。

由于 Docker 容器不运行自己的内核,我怀疑该文件来自主机操作系统。也许,libQt6Core依赖于linux-vdso.so.1centos7内核无法提供的某些功能?我不知道 ... 在此处输入图像描述


由于到目前为止我没有尝试过产生错误消息,因此我不知道实际问题可能是什么或如何进行调试。对于任何类型的提示、提示或帮助,我将不胜感激。

compiling docker
  • 1 个回答
  • 367 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve