-
Notifications
You must be signed in to change notification settings - Fork 379
NVIDIA driver support for docker container
Proprietary closed source drivers from NVIDIA corporation need some manual setup and have some constraints. Consider to use free nouveau
driver instead.
The image needs the very same NVIDIA driver version in image as on host. Basically there a two ways that make sense:
-
Providing an NVIDIA installer for automated installation in container by x11docker. Useful e.g. for developers who want to deploy images with OpenGL applications.
- Advantage: This is flexible and portable and does not need specific image setups.
- Drawback: Automated install of NVIDIA driver slows down every container startup a bit.
-
Creating a base image with an NVIDIA driver that matches the NVIDIA driver on host. Other images base upon that.
- Advantage: Best performance and disk space usage for end users that want to set up several containerized applications for own use.
- Drawbacks: Every update of the NVIDIA driver on host needs a rebuild of all images. The base image matches a few host systems only and is not portable.
For usage of NVIDIA GPU without x11docker look at wiki: How to set up GPU hardware acceleration for docker containers.
x11docker can automatically install closed source NVIDIA drivers in container at every container startup. It gives some setup instructions and a probably matching download link in terminal output.
- x11docker needs an installer file that matches the version on host. It must not be a
deb
orrpm
package but anNVIDIA_[...].run
file. Store it at one of the following locations:-
~/.local/share/x11docker
(current user only) -
/usr/local/share/x11docker
(system wide)
-
- Find out installed NVIDIA driver version on host with:
head -n1 </proc/driver/nvidia/version | awk '{ print $8 }'
- Look at NVIDIA driver download page or try the direct download link provided in x11docker terminal output.
Script to build a base image with NVIDIA driver matching the version on host. (Not needed if using automated installation as described above).
#! /bin/bash
# Script to build image x11docker/nvidia-base
# containing NVIDIA driver version matching the one on host.
Imagename="x11docker/nvidia-base"
Nvidiaversion="$(head -n1 </proc/driver/nvidia/version | awk '{ print $8 }')"
[ "$Nvidiaversion" ] || {
echo "Error: No NVIDIA driver detected on host" >&2
exit 1
}
echo "Detected NVIDIA driver version: $Nvidiaversion"
Driverurl="https://http.download.nvidia.com/XFree86/Linux-x86_64/$Nvidiaversion/NVIDIA-Linux-x86_64-$Nvidiaversion.run"
echo "Driver download URL: $Driverurl"
Tmpdir="/tmp/x11docker-nvidia-base"
mkdir -p "$Tmpdir"
echo "# Dockerfile to create NVIDIA driver base image $Imagename
FROM debian:stable
RUN apt-get update && \
apt-get install --no-install-recommends -y kmod xz-utils wget ca-certificates binutils && \
wget $Driverurl -O /tmp/NVIDIA-installer.run && \
sh /tmp/NVIDIA-installer.run -A | grep -q 'install-libglvnd' && Libglvnd='--install-libglvnd' ; \
sh /tmp/NVIDIA-installer.run -A | grep -q 'no-nvidia-modprobe' && Nvidiamodprobe='--no-nvidia-modprobe' ; \
sh /tmp/NVIDIA-installer.run \
--accept-license --no-runlevel-check --no-questions --no-backup --ui=none \$Libglvnd \
--no-kernel-module --no-kernel-module-source --no-nouveau-check \$Nvidiamodprobe || echo 'Error while installing NVIDIA driver' ; \
rm /tmp/NVIDIA-installer.run && \
apt-get remove -y kmod xz-utils wget ca-certificates binutils && \
apt-get autoremove -y && apt-get clean -y
" >"$Tmpdir/Dockerfile"
echo "Creating docker image $Imagename"
docker build -t $Imagename $Tmpdir || {
echo "Error: Failed to build image $Imagename.
Check possible build error messages above.
Make sure that you have permission to start docker.
Make sure docker daemon is running." >&2
rm -R "$Tmpdir"
exit 1
}
echo "Successfully created $Imagename"
rm -R "$Tmpdir"
exit 0
If your host system is configured for NVIDIA/nvidia-docker, you can use the according images with x11docker adding docker run option --runtime=nvidia
. Example:
x11docker --gpu -- --runtime=nvidia -- nvidia/cuda nvidia-smi
- NVIDIA does not support Wayland that is needed for some more advanced x11docker X server options. Hardware acceleration (option
--gpu
) with proprietary NVIDIA drivers will only work for insecure option--hostdisplay
and for option--xorg
. - Closed source NVIDIA driver installation fails in container systems that are not based on
glibc
. This affects especially Alpine based images. NVIDIA corporation does not provide the source code that would allow you to use your hardware with different systems. - Free
nouveau
driver for NVIDIA cards works quite well with x11docker and does not need a special setup. However, NVIDIA corporation does not publish the API of your NVIDIA card. The developers ofnouveau
are forced to spend their power in a lot of reverse engineering. Due to this constrained policy of NVIDIA corporation the free and open sourcenouveau
driver cannot support all features of NVIDIA cards. - To be honest.