gpt4 book ai didi

linux - C++ 可执行文件在 scp 之后无法链接到共享库

转载 作者:太空宇宙 更新时间:2023-11-03 17:18:49 43 4
gpt4 key购买 nike

所以我正在开发一个旨在在远程服务器上运行的项目。我在本地电脑上开发程序,编译它,然后上传到远程服务器。本地电脑和远程服务器都运行在 CentOS 7.7 上。

该程序是使用 CLion IDE 开发的,并配置了 CMake。该程序依赖于一些共享库,这些共享库应该根据我在 CMake 中编写的内容链接到可执行文件。在我的本地 PC 上,我可以完美地编译和运行程序。但是,在我将项目的整个目录scp 到远程服务器后,可执行文件无法运行。根据 ldd 所说,它找不到任何“.so”文件。

这是我的 CMakeList.txt,每条路径都是相对路径,而不是绝对路径。

cmake_minimum_required(VERSION 3.15)
project(YS_Test)

set(CMAKE_CXX_STANDARD 11)

set(SOURCE_PATH_ src)

file(GLOB SOURCE_FILES_ ${SOURCE_PATH_}/*.*)

set(PROJECT_LIBS_ libTapQuoteAPI.so libTapTradeAPI.so libTapDataCollectAPI.so)

include_directories(api/include)
link_directories(api/lib/linux)

add_executable(YS_Test ${SOURCE_FILES_})

target_link_libraries(YS_Test ${PROJECT_LIBS_})

请不要告诉我设置 LD_LIBRARY_PATH 来解决我的问题。该程序在没有 LD_LIBRARY_PATH 的情况下在我的本地电脑上运行良好,因此我希望它在没有 LD_LIBRARY_PATH 的远程服务器上运行。我想知道这里到底发生了什么,而不是变通。谢谢!

最佳答案

如果我对您的问题的理解正确,您希望将已编译的 YS_Test 程序连同一些依赖项一起发布,并让它在远程服务器上运行。默认情况下,可执行文件只会查找在 /etc/ld.so 中配置的目录,其中不包括部署路径。

注意:通常您不会部署整个构建目录,而只会部署已编译的工件和依赖项。对于这个答案,我假设您将二进制文件及其依赖项部署到相同目录。

你有两个选择:

  • 要求您的程序的用户自行或通过包装脚本设置LD_LIBRARY_PATH。该变量将指示动态链接器也查看指定的目录。即使您不喜欢这种解决方案,它也是迄今为止最常用的方法。
  • -Wl,-rpath='$ORIGIN' 添加到您的链接器选项。这会将 DT_RUNPATH 属性添加到可执行文件的动态部分。当您使用 CMake 时,您还可以使用 BUILD_RPATH 和/或 INSTALL_RPATH 目标属性进行设置。ld.so 联机帮助页对此属性的描述如下:

    If a shared object dependency does not contain a slash, then it is searched for in the following order:

    • ...
    • Using the directories specified in the DT_RUNPATH dynamic section attribute of the binary if present.

    $ORIGIN 部分扩展到包含程序或共享的目录 对象。

如果您真的坚持发布您的构建目录(例如在开发期间),您可以查看 CMake BUILD_RPATH_USE_ORIGIN属性(及其通常的全局对应项 CMAKE_BUILD_RPATH_USE_ORIGIN),这会将相对路径而不是绝对路径嵌入到二进制文件中。

关于linux - C++ 可执行文件在 scp 之后无法链接到共享库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58969832/

43 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com