| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390 |
- # This Source Code Form is subject to the terms of the Mozilla Public
- # License, v. 2.0. If a copy of the MPL was not distributed with this
- # file, You can obtain one at https://mozilla.org/MPL/2.0/.
- # Ubuntu release versions 22.04, 20.04, and 18.04 are supported
- ARG UBUNTU_RELEASE=22.04
- ARG CUDA_VERSION=11.7.1
- FROM nvcr.io/nvidia/cuda:${CUDA_VERSION}-runtime-ubuntu${UBUNTU_RELEASE}
- LABEL maintainer "https://github.com/ehfd,https://github.com/danisla"
- ARG UBUNTU_RELEASE
- ARG CUDA_VERSION
- # Make all NVIDIA GPUs visible by default
- ARG NVIDIA_VISIBLE_DEVICES=all
- # Use noninteractive mode to skip confirmation when installing packages
- ARG DEBIAN_FRONTEND=noninteractive
- # All NVIDIA driver capabilities should preferably be used, check `NVIDIA_DRIVER_CAPABILITIES` inside the container if things do not work
- ENV NVIDIA_DRIVER_CAPABILITIES all
- # Enable AppImage execution in a container
- ENV APPIMAGE_EXTRACT_AND_RUN 1
- # System defaults that should not be changed
- ENV DISPLAY :0
- ENV XDG_RUNTIME_DIR /tmp/runtime-user
- ENV PULSE_SERVER unix:/run/pulse/native
- ENV LD_LIBRARY_PATH /usr/lib/x86_64-linux-gnu:/usr/lib/i386-linux-gnu${LD_LIBRARY_PATH:+:${LD_LIBRARY_PATH}}
- # Default environment variables (password is "mypasswd")
- ENV TZ UTC
- ENV SIZEW 1920
- ENV SIZEH 1080
- ENV REFRESH 60
- ENV DPI 96
- ENV CDEPTH 24
- ENV VIDEO_PORT DFP
- ENV PASSWD mypasswd
- ENV NOVNC_ENABLE false
- ENV WEBRTC_ENCODER nvh264enc
- ENV WEBRTC_ENABLE_RESIZE false
- ENV ENABLE_AUDIO true
- ENV ENABLE_BASIC_AUTH true
- # Set versions for components that should be manually checked before upgrading, other component versions are automatically determined by fetching the version online
- ARG NOVNC_VERSION=1.3.0
- # Install locales to prevent X11 errors
- RUN apt-get clean && \
- apt-get update && apt-get install --no-install-recommends -y locales && \
- rm -rf /var/lib/apt/lists/* && \
- locale-gen en_US.UTF-8
- ENV LANG en_US.UTF-8
- ENV LANGUAGE en_US:en
- ENV LC_ALL en_US.UTF-8
- # Install Xorg and other important libraries or packages
- RUN dpkg --add-architecture i386 && \
- apt-get update && apt-get install --no-install-recommends -y \
- software-properties-common \
- alsa-base \
- alsa-utils \
- apt-transport-https \
- apt-utils \
- build-essential \
- ca-certificates \
- cups-filters \
- cups-common \
- cups-pdf \
- curl \
- file \
- wget \
- bzip2 \
- gzip \
- p7zip-full \
- xz-utils \
- zip \
- unzip \
- zstd \
- gcc \
- git \
- jq \
- make \
- python3 \
- python3-cups \
- python3-numpy \
- mlocate \
- nano \
- vim \
- htop \
- fonts-dejavu-core \
- fonts-freefont-ttf \
- fonts-noto \
- fonts-noto-cjk \
- fonts-noto-cjk-extra \
- fonts-noto-color-emoji \
- fonts-noto-hinted \
- fonts-noto-mono \
- fonts-opensymbol \
- fonts-symbola \
- fonts-ubuntu \
- libpulse0 \
- pulseaudio \
- supervisor \
- net-tools \
- libglvnd-dev \
- libglvnd-dev:i386 \
- libgl1-mesa-dev \
- libgl1-mesa-dev:i386 \
- libegl1-mesa-dev \
- libegl1-mesa-dev:i386 \
- libgles2-mesa-dev \
- libgles2-mesa-dev:i386 \
- libglvnd0 \
- libglvnd0:i386 \
- libgl1 \
- libgl1:i386 \
- libglx0 \
- libglx0:i386 \
- libegl1 \
- libegl1:i386 \
- libgles2 \
- libgles2:i386 \
- libglu1 \
- libglu1:i386 \
- libsm6 \
- libsm6:i386 \
- vainfo \
- vdpauinfo \
- pkg-config \
- mesa-utils \
- mesa-utils-extra \
- va-driver-all \
- xserver-xorg-input-all \
- xserver-xorg-video-all \
- mesa-vulkan-drivers \
- libvulkan-dev \
- libvulkan-dev:i386 \
- libxau6 \
- libxau6:i386 \
- libxdmcp6 \
- libxdmcp6:i386 \
- libxcb1 \
- libxcb1:i386 \
- libxext6 \
- libxext6:i386 \
- libx11-6 \
- libx11-6:i386 \
- libxv1 \
- libxv1:i386 \
- libxtst6 \
- libxtst6:i386 \
- xdg-utils \
- dbus-x11 \
- libdbus-c++-1-0v5 \
- xkb-data \
- x11-xkb-utils \
- x11-xserver-utils \
- x11-utils \
- x11-apps \
- xauth \
- xbitmaps \
- xinit \
- xfonts-base \
- libxrandr-dev \
- # Install essential Xorg and NVIDIA packages, packages above this line should be the same between docker-nvidia-glx-desktop and docker-nvidia-egl-desktop
- kmod \
- libc6-dev \
- libc6:i386 \
- libpci3 \
- libelf-dev \
- xorg && \
- # Install Vulkan utilities
- if [ "${UBUNTU_RELEASE}" \< "20.04" ]; then apt-get install --no-install-recommends -y vulkan-utils; else apt-get install --no-install-recommends -y vulkan-tools; fi && \
- rm -rf /var/lib/apt/lists/* && \
- # Configure EGL manually
- mkdir -p /usr/share/glvnd/egl_vendor.d/ && \
- echo "{\n\
- \"file_format_version\" : \"1.0.0\",\n\
- \"ICD\": {\n\
- \"library_path\": \"libEGL_nvidia.so.0\"\n\
- }\n\
- }" > /usr/share/glvnd/egl_vendor.d/10_nvidia.json
- # Anything below this line should be always kept the same between docker-nvidia-glx-desktop and docker-nvidia-egl-desktop
- # Install KDE and other GUI packages
- ENV XDG_CURRENT_DESKTOP KDE
- ENV KWIN_COMPOSE N
- # Use sudoedit to change protected files instead of using sudo on kate
- ENV SUDO_EDITOR kate
- RUN mkdir -pm755 /etc/apt/preferences.d && \
- echo "Package: firefox*\n\
- Pin: release o=Ubuntu*\n\
- Pin-Priority: -1" > /etc/apt/preferences.d/firefox-ppa && \
- add-apt-repository -y ppa:mozillateam/ppa && \
- apt-get update && apt-get install --no-install-recommends -y \
- kde-plasma-desktop \
- kwin-addons \
- kwin-x11 \
- kdeadmin \
- akregator \
- ark \
- baloo-kf5 \
- breeze-cursor-theme \
- breeze-icon-theme \
- debconf-kde-helper \
- colord-kde \
- desktop-file-utils \
- filelight \
- gwenview \
- hspell \
- kaddressbook \
- kaffeine \
- kate \
- kcalc \
- kcharselect \
- kdeconnect \
- kde-spectacle \
- kdf \
- kget \
- kgpg \
- khelpcenter \
- khotkeys \
- kimageformat-plugins \
- kinfocenter \
- kio-extras \
- kleopatra \
- kmail \
- kmenuedit \
- kmix \
- knotes \
- kontact \
- kopete \
- korganizer \
- krdc \
- ktimer \
- kwalletmanager \
- okular \
- okular-extra-backends \
- plasma-dataengines-addons \
- plasma-discover \
- plasma-runners-addons \
- plasma-wallpapers-addons \
- plasma-widgets-addons \
- plasma-workspace-wallpapers \
- qtvirtualkeyboard-plugin \
- sonnet-plugins \
- sweeper \
- systemsettings \
- xdg-desktop-portal-kde \
- kubuntu-restricted-extras \
- kubuntu-wallpapers \
- firefox \
- pavucontrol-qt \
- transmission-qt && \
- apt-get install --install-recommends -y \
- libreoffice \
- libreoffice-style-breeze && \
- rm -rf /var/lib/apt/lists/* && \
- # Fix KDE startup permissions issues in containers
- cp -f /usr/lib/x86_64-linux-gnu/libexec/kf5/start_kdeinit /tmp/ && \
- rm -f /usr/lib/x86_64-linux-gnu/libexec/kf5/start_kdeinit && \
- cp -r /tmp/start_kdeinit /usr/lib/x86_64-linux-gnu/libexec/kf5/start_kdeinit && \
- rm -f /tmp/start_kdeinit
- # Wine, Winetricks, Lutris, and PlayOnLinux, this process must be consistent with https://wiki.winehq.org/Ubuntu
- ARG WINE_BRANCH=staging
- RUN if [ "${UBUNTU_RELEASE}" \< "20.04" ]; then add-apt-repository -y ppa:cybermax-dexter/sdl2-backport; fi && \
- mkdir -pm755 /etc/apt/keyrings && curl -fsSL -o /etc/apt/keyrings/winehq-archive.key "https://dl.winehq.org/wine-builds/winehq.key" && \
- curl -fsSL -o "/etc/apt/sources.list.d/winehq-$(grep VERSION_CODENAME= /etc/os-release | cut -d= -f2).sources" "https://dl.winehq.org/wine-builds/ubuntu/dists/$(grep VERSION_CODENAME= /etc/os-release | cut -d= -f2)/winehq-$(grep VERSION_CODENAME= /etc/os-release | cut -d= -f2).sources" && \
- apt-get update && apt-get install --install-recommends -y \
- winehq-${WINE_BRANCH} && \
- apt-get install --no-install-recommends -y \
- q4wine \
- playonlinux && \
- LUTRIS_VERSION=$(curl -fsSL "https://api.github.com/repos/lutris/lutris/releases/latest" | jq -r '.tag_name' | sed 's/[^0-9\.\-]*//g') && \
- curl -fsSL -O "https://github.com/lutris/lutris/releases/download/v${LUTRIS_VERSION}/lutris_${LUTRIS_VERSION}_all.deb" && \
- apt-get install --no-install-recommends -y ./lutris_${LUTRIS_VERSION}_all.deb && rm -f "./lutris_${LUTRIS_VERSION}_all.deb" && \
- rm -rf /var/lib/apt/lists/* && \
- curl -fsSL -o /usr/bin/winetricks "https://raw.githubusercontent.com/Winetricks/winetricks/master/src/winetricks" && \
- chmod 755 /usr/bin/winetricks && \
- curl -fsSL -o /usr/share/bash-completion/completions/winetricks "https://raw.githubusercontent.com/Winetricks/winetricks/master/src/winetricks.bash-completion"
- # Install latest selkies-gstreamer (https://github.com/selkies-project/selkies-gstreamer) build, Python application, and web application, should be consistent with selkies-gstreamer documentation
- RUN apt-get update && apt-get install --no-install-recommends -y \
- build-essential \
- python3-pip \
- python3-dev \
- python3-gi \
- python3-setuptools \
- python3-wheel \
- tzdata \
- sudo \
- udev \
- xclip \
- x11-utils \
- xdotool \
- wmctrl \
- jq \
- gdebi-core \
- x11-xserver-utils \
- xserver-xorg-core \
- libopus0 \
- libgdk-pixbuf2.0-0 \
- libsrtp2-1 \
- libxdamage1 \
- libxml2-dev \
- libwebrtc-audio-processing1 \
- libcairo-gobject2 \
- pulseaudio \
- libpulse0 \
- libpangocairo-1.0-0 \
- libgirepository1.0-dev \
- libjpeg-dev \
- libvpx-dev \
- zlib1g-dev \
- x264 && \
- if [ "${UBUNTU_RELEASE}" \> "20.04" ]; then apt-get install --no-install-recommends -y xcvt; fi && \
- rm -rf /var/lib/apt/lists/* && \
- cd /opt && \
- # Automatically fetch the latest selkies-gstreamer version and install the components
- SELKIES_VERSION=$(curl -fsSL "https://api.github.com/repos/selkies-project/selkies-gstreamer/releases/latest" | jq -r '.tag_name' | sed 's/[^0-9\.\-]*//g') && \
- curl -fsSL "https://github.com/selkies-project/selkies-gstreamer/releases/download/v${SELKIES_VERSION}/selkies-gstreamer-v${SELKIES_VERSION}-ubuntu${UBUNTU_RELEASE}.tgz" | tar -zxf - && \
- curl -O -fsSL "https://github.com/selkies-project/selkies-gstreamer/releases/download/v${SELKIES_VERSION}/selkies_gstreamer-${SELKIES_VERSION}-py3-none-any.whl" && pip3 install "selkies_gstreamer-${SELKIES_VERSION}-py3-none-any.whl" && rm -f "selkies_gstreamer-${SELKIES_VERSION}-py3-none-any.whl" && \
- curl -fsSL "https://github.com/selkies-project/selkies-gstreamer/releases/download/v${SELKIES_VERSION}/selkies-gstreamer-web-v${SELKIES_VERSION}.tgz" | tar -zxf - && \
- cd /usr/local/cuda/lib64 && sudo find . -maxdepth 1 -type l -name "*libnvrtc.so.*" -exec sh -c 'ln -snf $(basename {}) libnvrtc.so' \;
- # Install the noVNC web interface and the latest x11vnc for fallback
- RUN apt-get update && apt-get install --no-install-recommends -y \
- autoconf \
- automake \
- autotools-dev \
- chrpath \
- debhelper \
- git \
- jq \
- python3 \
- python3-numpy \
- libc6-dev \
- libcairo2-dev \
- libjpeg-turbo8-dev \
- libssl-dev \
- libv4l-dev \
- libvncserver-dev \
- libtool-bin \
- libxdamage-dev \
- libxinerama-dev \
- libxrandr-dev \
- libxss-dev \
- libxtst-dev \
- libavahi-client-dev && \
- rm -rf /var/lib/apt/lists/* && \
- # Build the latest x11vnc source to avoid various errors
- git clone "https://github.com/LibVNC/x11vnc.git" /tmp/x11vnc && \
- cd /tmp/x11vnc && autoreconf -fi && ./configure && make install && cd / && rm -rf /tmp/* && \
- curl -fsSL "https://github.com/novnc/noVNC/archive/v${NOVNC_VERSION}.tar.gz" | tar -xzf - -C /opt && \
- mv -f "/opt/noVNC-${NOVNC_VERSION}" /opt/noVNC && \
- ln -snf /opt/noVNC/vnc.html /opt/noVNC/index.html && \
- # Use the latest Websockify source to expose noVNC
- git clone "https://github.com/novnc/websockify.git" /opt/noVNC/utils/websockify
- # Add custom packages right below this comment, or use FROM in a new container and replace entrypoint.sh or supervisord.conf, and set ENTRYPOINT to /usr/bin/supervisord
- # Create user with password ${PASSWD} and assign adequate groups
- RUN apt-get update && apt-get install --no-install-recommends -y \
- sudo && \
- rm -rf /var/lib/apt/lists/* && \
- groupadd -g 1000 user && \
- useradd -ms /bin/bash user -u 1000 -g 1000 && \
- usermod -a -G adm,audio,cdrom,dialout,dip,fax,floppy,input,lp,lpadmin,plugdev,pulse-access,scanner,sudo,tape,tty,video,voice user && \
- echo "user ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers && \
- chown user:user /home/user && \
- echo "user:${PASSWD}" | chpasswd && \
- ln -snf "/usr/share/zoneinfo/$TZ" /etc/localtime && echo "$TZ" > /etc/timezone
- # Copy scripts and configurations used to start the container
- COPY entrypoint.sh /etc/entrypoint.sh
- RUN chmod 755 /etc/entrypoint.sh
- COPY selkies-gstreamer-entrypoint.sh /etc/selkies-gstreamer-entrypoint.sh
- RUN chmod 755 /etc/selkies-gstreamer-entrypoint.sh
- COPY supervisord.conf /etc/supervisord.conf
- RUN chmod 755 /etc/supervisord.conf
- EXPOSE 8080
- USER user
- ENV SHELL /bin/bash
- ENV USER user
- WORKDIR /home/user
- ENTRYPOINT ["/usr/bin/supervisord"]
|