王柳 发表于 2025-1-6 10:45:04

libonnxruntime_providers_cuda.so with error: libcudnn_adv.so.9

在安装了 onnxruntime-gpu 后,使用 CUDA 时报错:
2025-01-02 11:40:03.935340441 /onnxruntime_src/onnxruntime/core/session/provider_bridge_ort.cc:1539 onnxruntime::Provider& onnxruntime::ProviderLibrary::Get() : 1 : FAIL : Failed to load library libonnxruntime_providers_cuda.so with error: libcudnn_adv.so.9: cannot open shared object file: No such file or directory

2025-01-02 11:40:03.935371734 Failed to create CUDAExecutionProvider. Require cuDNN 9.* and CUDA 12.*. Please install all dependencies as mentioned in the GPU requirements page (https://onnxruntime.ai/docs/execution-providers/CUDA-ExecutionProvider.html#requirements), make sure they're in the PATH, and that your GPU is supported.
很明显,cudnn 并为精确设置。
首先必要说明:
   PyTorch 的许多预编译版本(如通过 pip 或 conda 安装)会自带 CUDA 和 cuDNN。它会直接使用打包的版本,而不是依赖系统中全局安装的库。
    ONNX Runtime 必要系统中明白安装且可用的 cuDNN 动态库
安装 cudnn,留意版本对应:
https://developer.nvidia.com/cudnn-downloads
proxychains4 wget https://developer.download.nvidia.com/compute/cudnn/redist/cudnn/linux-x86_64/cudnn-linux-x86_64-9.1.0.70_cuda12-arch
ive.tar.xz
解压下载的文件:
tar -xvf cudnn-linux-x86_64-9.1.0.70_cuda12-archive.tar.xz
解压后,会看到一个名为 cuda 的目录,包罗以下子目录:


[*]include/: 包罗头文件,如 cudnn.h
[*]lib/: 包罗动态库,如 libcudnn.so
将解压出来的文件复制到系统的 CUDA 安装路径(默认路径是 /usr/local/cuda/):
sudo cp ./cudnn-linux-x86_64-9.1.0.70_cuda12-archive/include/* /usr/local/cuda-12.4/include/

sudo cp ./cudnn-linux-x86_64-9.1.0.70_cuda12-archive/lib/* /usr/local/cuda-12.4/lib64/
更新动态链接库缓存,以确保系统可以精确找到 cuDNN 的动态库文件:
检查 LD_LIBRARY_PATH 是否包罗 /usr/local/cuda/lib64:
echo $LD_LIBRARY_PATH
如果没有包罗,编辑 ~/.bashrc 文件,添加以下内容:
export LD_LIBRARY_PATH=/usr/local/cuda/lib64:$LD_LIBRARY_PATH
source ~/.bashrc
更新动态库缓存:
sudo ldconfig
验证 cuDNN 是否精确安装:
ls /usr/local/cuda/lib64 | grep libcudnn
输出:
libcudnn_adv.so
libcudnn_adv.so.9
libcudnn_adv.so.9.1.0
libcudnn_adv_static.a
libcudnn_adv_static_v9.a
libcudnn_cnn.so
...
检查 cuDNN 版本:
cat /usr/local/cuda/include/cudnn_version.h | grep CUDNN_MAJOR -A 2
输出:
#define CUDNN_MAJOR 9
#define CUDNN_MINOR 1
#define CUDNN_PATCHLEVEL 0

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: libonnxruntime_providers_cuda.so with error: libcudnn_adv.so.9