根据你提供的错误信息,CMake 遇到了两个问题:
- 未找到 LibSSH2:缺少必要的库和包含文件。
- CA 路径支持的问题:如之前提到的,这个问题需要 TLS 后端。
解决方案
1. 安装 LibSSH2
确保系统中安装了 LibSSH2 库。如果没有,可以使用以下命令进行安装(具体命令可能因操作系统不同而有所不同):
对于 Ubuntu 或 Debian 系统:
sudo apt-get update sudo apt-get install libssh2-1-dev
对于 CentOS 或 RHEL 系统:
sudo yum install libssh2-devel
对于 macOS 使用 Homebrew:
brew install libssh2
在安装完成后,重新运行 CMake。
2. 启用一个 TLS 后端
正如之前所提到的,你需要启用 OpenSSL、GnuTLS 或 mbed TLS 中的一种。确保你已安装其中一个库并配置正确。例如,如果选择使用 OpenSSL,请执行以下步骤:
安装 OpenSSL(如果尚未安装):
Ubuntu / Debian:
sudo apt-get install libssl-dev
CentOS / RHEL:
sudo yum install openssl-devel
macOS (Homebrew):
brew install openssl@1.1 # 确保版本与你的项目兼容
指定 CMake 使用 OpenSSL:
在 CMake 配置时,通过设置选项来启用它:
cmake -DOPENSSL_ROOT_DIR=/usr/local/opt/openssl@1.1 .. # 根据实际情况修改路径
或简单地通过命令:
cmake -DCMAKE_USE_OPENSSL=ON ..
3. 设置 CURL_CA_PATH
如果不想使用任何 TLS 后端,并希望跳过 CA 路径检查,可以设置环境变量 CURL_CA_PATH
为 none
:
export CURL_CA_PATH=none # Linux/macOS terminal 中执行此命令
然后重新运行 CMake。
总结
这两个问题是独立的,首先确保 LibSSH2 正确安装,然后根据你的需求配置适当的 TLS 后端。如果还有其他问题或错误信息,请提供详细信息,以便进一步帮助!
内容由零声教学AI助手提供,问题来源于学员提问