I am trying to run an application inside a docker container in Windows 10.
But I am not able to get the GPU working inside docker.
I read that it needs "GPU Pass-through."
How should I get around this?
I am trying to run an application inside a docker container in Windows 10.
But I am not able to get the GPU working inside docker.
I read that it needs "GPU Pass-through."
How should I get around this?
Update (December 2020) You can now do GPU pass-through on Windows, if you use WSL 2 as the backend for Docker: WSL 2 GPU Support is Here - that is a slightly neater method than running Docker inside WSL.
Original answer:
GPU access from within a Docker container currently isn't supported on Windows.
You need nvidia-docker
, but that is currently only supported on Linux platforms. GPU passthrough with Hyper-v would require Discrete Device Assignment (DDA), which is currently only in Windows Server, and (at least in 2015) there was no plan to change that state of affairs. Hence, NVIDIA are not porting nvidia-docker
to Windows at the moment.
A bit more info here: https://devblogs.nvidia.com/nvidia-docker-gpu-server-application-deployment-made-easy/
Update (October 2019): nvidia-docker
is deprecated, as Docker 19.03 has native support for NVIDIA GPUs. Instead install nvidia-container-runtime
, and use the docker run --gpus all
flag. You can also run Windows Containers with GPU acceleration on a Windows host, using Docker 19.03, but not a Linux container.
Update (August 2020): It looks like you can now do GPU pass-through when running Docker inside the Windows Subsystem for Linux (WSL 2).
This link goes through installation, setup and running a TensorFlow Jupyter notebook inside Docker in Ubuntu in WSL 2, with GPU support: https://ubuntu.com/blog/getting-started-with-cuda-on-ubuntu-on-wsl-2
Note - I haven't done this myself yet.
nvidia-container-runtime
? –
Babar TLDR: If you're using the latest versions of Windows 11, NVIDIA drivers, and Docker Desktop, this should work pretty much out of the box. Try with this command: docker run --rm -it --gpus=all nvcr.io/nvidia/k8s/cuda-sample:nbody
I was successful with training models on GPU in TensorFlow 2 using this method.
Settings - General - Use the WSL2 backed engine
.docker
CLI from inside WSL2 (not just from PowerShell/cmd), enable the integration in Settings - Resources - WSL INTEGRATION
.docker run --rm -it --gpus=all nvcr.io/nvidia/k8s/cuda-sample:nbody
You need to pass --gpus=all
to docker run
to enable the container to access GPU. (If you use VSCode Remote Containers, add "runArgs": ["--gpus=all"],
to devcontainer.json
.)
You may come across mentions of --runtime=nvidia
in descriptions of images meant for nvidia-docker
(like the official TensorFlow images). Simply replace --runtime=nvidia
by --gpus=all
in the provided commands.
docker
command from WSL, or use the `\\wsl$` filesystem. –
To Now that docker on Windows 10 can access WSL2 (as of Windows 10 version 2004) it has cleared the way for GPU support of Linux docker containers on Windows 10.
According to this official blog, MS "will start previewing GPU compute support for WSL in Windows 10 Insider builds within the next few months": https://devblogs.microsoft.com/commandline/the-windows-subsystem-for-linux-build-2020-summary/#wsl-gpu
I expect Docker GPU support to follow shortly after.
Update:
GPU pass-through in Windows is now possible under very specific circumstances, including:
Update 2:
GPU pass through from Linux docker on Windows host is now possible on the latest Windows Insider build, refer to:
https://ubuntu.com/blog/getting-started-with-cuda-on-ubuntu-on-wsl-2
This will flow through to mainstream Windows probably in the next major update.
Update 3:
Confirmed that Windows build version 2021 will include GPU pass-through for WSL. See details of the announcement here: https://blogs.windows.com/windowsdeveloper/2021/05/25/the-windows-developers-guide-to-microsoft-build-2021/
Provide a sample !
ffmpeg -hide_banner -codecs | grep 264
DEV.LS h264 H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10 (decoders: h264 h264_v4l2m2m h264_cuvid ) (encoders: h264_nvenc h264_v4l2m2m nvenc nvenc_h264 )
This would show that the ffmpeg verion can handle: h264_nvenc
nvenc
nvenc_h264
ffmpeg -i video.mp4 -vf scale=iw/2:ih/2 -vcodec h264_nvenc "video_2.mp4"
On my WSL2/Insider I get a message that I don't have the correct nvidia driver installed. Because the drive is installed down-below in the windows OS.
Queries with Microsoft and NVIDIA turned out the hardware acceleration is not passed through and they have no near future plans to do so.
Windows docker on a widnows os, could be fine. Will check.
I think docker run --gpus all can resolve, you will need install nvidea drivers to your linux docker and cuda sdk. Other way I think is give all permissions using parameter --privileged: docker run --privileged and other parameters you need, you will nedd to think about because with privileged de docker can access your real machine.
Note that Hardware Acceleration of video decoding-encoding is not supported in the WSL2/windows-Insider implementation.
Thus, any GPU functions can be used with little limitations on WSL2 but video encoding-decoding cannot be done by the hardware.
Attempt to ask ffmpeg to use the hardware acceleration leads to error messages. (skvideo, which is an ffmpeg wrapper, crashes)
Not sure about gStreamer yet. But for sure it cannot use the Hardware Acceleration as it is not "funneled" through the interface.
As far as I know - there are no current plans to add ths support.
Best, Mickey
© 2022 - 2025 — McMap. All rights reserved.
nvidia-docker
is not the only option for GPU pass-through on UNIX-like OS's (or at least where devices are files) it should be possible to forward GPUs with the--device
flag. An example is the ROCm container. – Identify