使用非 debian 管理的库构建 debian 包

Building a debian package using non-debian managed libraries

我正在尝试构建一个使用 Qt5 库的 Debian 软件包。我在 /opt 中安装了 Qt,可以在 /opt/Qt/5.15.0/gcc_64/lib 找到这些库。

我试图放入 Debian 包中的二进制文件是用 C++ 编写的,我使用 CMake 作为构建系统。

我的 debian/rules 文件包含以下内容:

#!/usr/bin/make -f

DH_VERBOSE = 1

%:
        dh $@ --builddirectory=build

override_dh_auto_configure:
        dh_auto_configure -- -DQt5_DIR=/opt/Qt/5.15.0/gcc_64/lib/cmake/Qt5

override_dh_shlibdeps:
        dh_shlibdeps -l /opt/Qt/5.15.0/gcc_64/lib/ -- --ignore-missing-info

override_dh_shlibdeps 是我尝试将它链接到正确的库,但它没有。

我使用以下命令构建 Debian 软件包:debuild -us -uc

使用此规则文件,我通过 ldd 得到以下结果:

        linux-vdso.so.1 (0x00007ffff4ff5000)
        libgrpc++.so.1 => /lib/x86_64-linux-gnu/libgrpc++.so.1 (0x00007f35100c1000)
        libprotobuf.so.17 => /lib/x86_64-linux-gnu/libprotobuf.so.17 (0x00007f350fdc9000)
        libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f350fda6000)
        libQt5Qml.so.5 => not found
        libQt5Core.so.5 => /lib/x86_64-linux-gnu/libQt5Core.so.5 (0x00007f350f85d000)
        libstdc++.so.6 => /lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f350f67c000)
        libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f350f65f000)
        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f350f46d000)
        libgrpc.so.6 => /lib/x86_64-linux-gnu/libgrpc.so.6 (0x00007f350f319000)
        /lib64/ld-linux-x86-64.so.2 (0x00007f351015d000)
        libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007f350f2fd000)
        libicui18n.so.66 => /lib/x86_64-linux-gnu/libicui18n.so.66 (0x00007f350effe000)
        libicuuc.so.66 => /lib/x86_64-linux-gnu/libicuuc.so.66 (0x00007f350ee18000)
        libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f350ee10000)
        libpcre2-16.so.0 => /lib/x86_64-linux-gnu/libpcre2-16.so.0 (0x00007f350ed8d000)
        libdouble-conversion.so.3 => /lib/x86_64-linux-gnu/libdouble-conversion.so.3 (0x00007f350ed77000)
        libglib-2.0.so.0 => /lib/x86_64-linux-gnu/libglib-2.0.so.0 (0x00007f350ec4e000)
        libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f350eaff000)
        libssl.so.1.1 => /lib/x86_64-linux-gnu/libssl.so.1.1 (0x00007f350ea6c000)
        libcrypto.so.1.1 => /lib/x86_64-linux-gnu/libcrypto.so.1.1 (0x00007f350e794000)
        libcares.so.2 => /lib/x86_64-linux-gnu/libcares.so.2 (0x00007f350e780000)
        libicudata.so.66 => /lib/x86_64-linux-gnu/libicudata.so.66 (0x00007f350ccbf000)
        libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007f350cc4c000)

它找不到 libQt5Qml,因为我没有使用包管理器安装它。这并没有引发错误,因为我已经向其中添加了 --ignore-missing-info

那么有没有办法让它链接到 /opt/ 目录,而不是通过包管理器安装的目录?

应该是这样的,感兴趣的话:

        linux-vdso.so.1 (0x00007ffd3a907000)
        libgrpc++.so.1 => /lib/x86_64-linux-gnu/libgrpc++.so.1 (0x00007f3cdc735000)
        libprotobuf.so.17 => /lib/x86_64-linux-gnu/libprotobuf.so.17 (0x00007f3cdc43d000)
        libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f3cdc41a000)
        libQt5Qml.so.5 => /opt/Qt/5.15.0/gcc_64/lib/libQt5Qml.so.5 (0x00007f3cdbd9d000)
        libQt5Core.so.5 => /opt/Qt/5.15.0/gcc_64/lib/libQt5Core.so.5 (0x00007f3cdb5aa000)
        libstdc++.so.6 => /lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f3cdb3c9000)
        libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f3cdb3ac000)
        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f3cdb1ba000)
        libgrpc.so.6 => /lib/x86_64-linux-gnu/libgrpc.so.6 (0x00007f3cdb066000)
        /lib64/ld-linux-x86-64.so.2 (0x00007f3cdc7d1000)
        libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007f3cdb04a000)
        libQt5Network.so.5 => /opt/Qt/5.15.0/gcc_64/lib/libQt5Network.so.5 (0x00007f3cdac9c000)
        librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007f3cdac91000)
        libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f3cdab40000)
        libicui18n.so.56 => /opt/Qt/5.15.0/gcc_64/lib/libicui18n.so.56 (0x00007f3cda6a7000)
        libicuuc.so.56 => /opt/Qt/5.15.0/gcc_64/lib/libicuuc.so.56 (0x00007f3cda2ef000)
        libicudata.so.56 => /opt/Qt/5.15.0/gcc_64/lib/libicudata.so.56 (0x00007f3cd890c000)
        libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f3cd8906000)
        libgthread-2.0.so.0 => /lib/x86_64-linux-gnu/libgthread-2.0.so.0 (0x00007f3cd8901000)
        libglib-2.0.so.0 => /lib/x86_64-linux-gnu/libglib-2.0.so.0 (0x00007f3cd87d6000)
        libssl.so.1.1 => /lib/x86_64-linux-gnu/libssl.so.1.1 (0x00007f3cd8743000)
        libcrypto.so.1.1 => /lib/x86_64-linux-gnu/libcrypto.so.1.1 (0x00007f3cd846d000)
        libcares.so.2 => /lib/x86_64-linux-gnu/libcares.so.2 (0x00007f3cd8459000)
        libgssapi_krb5.so.2 => /lib/x86_64-linux-gnu/libgssapi_krb5.so.2 (0x00007f3cd840c000)
        libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007f3cd8397000)
        libkrb5.so.3 => /lib/x86_64-linux-gnu/libkrb5.so.3 (0x00007f3cd82ba000)
        libk5crypto.so.3 => /lib/x86_64-linux-gnu/libk5crypto.so.3 (0x00007f3cd8289000)
        libcom_err.so.2 => /lib/x86_64-linux-gnu/libcom_err.so.2 (0x00007f3cd8282000)
        libkrb5support.so.0 => /lib/x86_64-linux-gnu/libkrb5support.so.0 (0x00007f3cd8273000)
        libkeyutils.so.1 => /lib/x86_64-linux-gnu/libkeyutils.so.1 (0x00007f3cd826a000)
        libresolv.so.2 => /lib/x86_64-linux-gnu/libresolv.so.2 (0x00007f3cd824e000)

这是我构建它时在我的构建文件夹中得到的。

我想出了解决方法。 主要问题出在我的 CMake 文件中。

在我的 CMake 中,我刚刚做了 find_package(Qt5 COMPONENTS Core Quick REQUIRED)。但是 CMake install 不知道在哪里可以找到 link with.

的库

所以我不得不设置 CMAKE_INSTALL_RPATH 变量。在我的例子中,我必须将它设置为 /opt/Qt/5.15.0/gcc_64/lib/。 (这可以使用 -D 通过命令行完成)

为了自动执行此过程,我将变量基于 Qt5_DIR 变量,这是 CMake 查找所有 Qt 模块所需的变量。

get_filename_component(Qt5_CMAKE_DIR ${Qt5_DIR} DIRECTORY)
get_filename_component(Qt5_LIBRARY_DIR ${Qt5_CMAKE_DIR} DIRECTORY)
list(APPEND CMAKE_INSTALL_RPATH ${Qt5_LIBRARY_DIR})

只要 CMake 可以找到 Qt,默认情况下一切都会正确设置。

为了构建 Debian 软件包,在您的规则中包含以下内容很重要:

override_dh_shlibdeps:
        dh_shlibdeps -- --ignore-missing-info

因为 Qt 没有安装包管理器。

安装 Debian 软件包时,您还必须使用 --force-all,因为依赖项未随软件包一起提供,否则会失败。

最后:我不推荐使用这种方式来构建包,因为如果你想 share/distribute 你的包给其他人,这是不可维护的。