カスタムCUDA/cuDNNを使用するDebianホストのDocker Ubuntuコンテナ

カスタムCUDA/cuDNNを使用するDebianホストのDocker Ubuntuコンテナ

任意のNVIDIAドライバとCUDAバージョンがインストールされているDebian 11サーバーにアクセスできます。しかし、多くの人がサーバーを使用しているため、多くの人にはさまざまなバージョンのCUDAとcuDNNが必要です。だから私はdockerから私の環境を分離し、イメージからコンテナを作成することにしました。ここ

オンラインガイドによると、ホストにはNVIDIAドライバをインストール(移行)してインストールnvidia-container-toolkit(移行)する必要があります。その後、次を実行してイメージからコンテナを作成しました。

docker run -it --rm --gpus all nvidia/cuda:11.2.0-cudnn8-runtime-ubuntu20.04

イメージに接続すると正常に実行できますが、nvidia-smiCUDAのバージョンがホストシステムと同じで、cuDNNがまったくないようです(ホストには現在cuDNNはありません)。画像に両方をプリインストールする必要があることを正確に理解しています。

何が間違っているのか、必要に応じて特定のCUDA / cuDNNとドライバのバージョンを使用して孤立したコンテナを実装する方法を知っていますか?

答え1

nvidia-smiコンテナ内でshow CUDAバージョンを呼び出すと、ホストのCUDAバージョンが表示される理由がわかりませんが、間違った場所でcuDNNを探していることに気づきました。https://github.com/NVIDIA/nvidia-docker/issues/53 画像は次のようになります。 (nvidia-docker2もインストールしました)

何らかの理由でトレーニング時間が非常に遅くなりますが、これについてさらに調査する必要があり、イメージの設定とは関係がないようです(少なくともGPUはTensorflowで正しく表示されます)。

関連情報