feature: set sparse Dockerfile with Python interpreter only
This commit is contained in:
parent
da9c98689e
commit
a4d5573698
@ -2,7 +2,7 @@
|
|||||||
# The version of cudatoolkit must match those of the base image, see Dockerfile.pytorch
|
# The version of cudatoolkit must match those of the base image, see Dockerfile.pytorch
|
||||||
FROM nvidia/cuda:10.1-base-ubuntu18.04
|
FROM nvidia/cuda:10.1-base-ubuntu18.04
|
||||||
LABEL maintainer="Christoph Schranz <christoph.schranz@salzburgresearch.at>"
|
LABEL maintainer="Christoph Schranz <christoph.schranz@salzburgresearch.at>"
|
||||||
# The maintainers of subsequent sections may vary
|
# This is a concatenated Dockerfile, the maintainers of subsequent sections may vary.
|
||||||
|
|
||||||
############################################################################
|
############################################################################
|
||||||
#################### Dependency: jupyter/base-image ########################
|
#################### Dependency: jupyter/base-image ########################
|
||||||
@ -11,15 +11,19 @@ LABEL maintainer="Christoph Schranz <christoph.schranz@salzburgresearch.at>"
|
|||||||
# Copyright (c) Jupyter Development Team.
|
# Copyright (c) Jupyter Development Team.
|
||||||
# Distributed under the terms of the Modified BSD License.
|
# Distributed under the terms of the Modified BSD License.
|
||||||
|
|
||||||
# Ubuntu 18.04 (bionic)
|
# Ubuntu 20.04 (focal)
|
||||||
# https://hub.docker.com/_/ubuntu/?tab=tags&name=bionic
|
# https://hub.docker.com/_/ubuntu/?tab=tags&name=focal
|
||||||
ARG ROOT_CONTAINER=ubuntu:bionic-20200112@sha256:bc025862c3e8ec4a8754ea4756e33da6c41cba38330d7e324abd25c8e0b93300
|
# OS/ARCH: linux/amd64
|
||||||
|
ARG ROOT_CONTAINER=ubuntu:focal-20200423@sha256:238e696992ba9913d24cfc3727034985abd136e08ee3067982401acdc30cbf3f
|
||||||
|
|
||||||
LABEL maintainer="Jupyter Project <jupyter@googlegroups.com>"
|
LABEL maintainer="Jupyter Project <jupyter@googlegroups.com>"
|
||||||
ARG NB_USER="jovyan"
|
ARG NB_USER="jovyan"
|
||||||
ARG NB_UID="1000"
|
ARG NB_UID="1000"
|
||||||
ARG NB_GID="100"
|
ARG NB_GID="100"
|
||||||
|
|
||||||
|
# Fix DL4006
|
||||||
|
SHELL ["/bin/bash", "-o", "pipefail", "-c"]
|
||||||
|
|
||||||
USER root
|
USER root
|
||||||
|
|
||||||
# Install all OS dependencies for notebook server that starts but lacks all
|
# Install all OS dependencies for notebook server that starts but lacks all
|
||||||
@ -68,7 +72,7 @@ RUN echo "auth requisite pam_deny.so" >> /etc/pam.d/su && \
|
|||||||
chown $NB_USER:$NB_GID $CONDA_DIR && \
|
chown $NB_USER:$NB_GID $CONDA_DIR && \
|
||||||
chmod g+w /etc/passwd && \
|
chmod g+w /etc/passwd && \
|
||||||
fix-permissions $HOME && \
|
fix-permissions $HOME && \
|
||||||
fix-permissions "$(dirname $CONDA_DIR)"
|
fix-permissions $CONDA_DIR
|
||||||
|
|
||||||
USER $NB_UID
|
USER $NB_UID
|
||||||
WORKDIR $HOME
|
WORKDIR $HOME
|
||||||
@ -79,19 +83,20 @@ RUN mkdir /home/$NB_USER/work && \
|
|||||||
fix-permissions /home/$NB_USER
|
fix-permissions /home/$NB_USER
|
||||||
|
|
||||||
# Install conda as jovyan and check the md5 sum provided on the download site
|
# Install conda as jovyan and check the md5 sum provided on the download site
|
||||||
ENV MINICONDA_VERSION=4.7.12.1 \
|
ENV MINICONDA_VERSION=4.8.2 \
|
||||||
MINICONDA_MD5=81c773ff87af5cfac79ab862942ab6b3 \
|
MINICONDA_MD5=87e77f097f6ebb5127c77662dfc3165e \
|
||||||
CONDA_VERSION=4.7.12
|
CONDA_VERSION=4.8.2
|
||||||
|
|
||||||
RUN cd /tmp && \
|
WORKDIR /tmp
|
||||||
wget --quiet https://repo.continuum.io/miniconda/Miniconda3-${MINICONDA_VERSION}-Linux-x86_64.sh && \
|
RUN wget --quiet https://repo.continuum.io/miniconda/Miniconda3-py37_${MINICONDA_VERSION}-Linux-x86_64.sh && \
|
||||||
echo "${MINICONDA_MD5} *Miniconda3-${MINICONDA_VERSION}-Linux-x86_64.sh" | md5sum -c - && \
|
echo "${MINICONDA_MD5} *Miniconda3-py37_${MINICONDA_VERSION}-Linux-x86_64.sh" | md5sum -c - && \
|
||||||
/bin/bash Miniconda3-${MINICONDA_VERSION}-Linux-x86_64.sh -f -b -p $CONDA_DIR && \
|
/bin/bash Miniconda3-py37_${MINICONDA_VERSION}-Linux-x86_64.sh -f -b -p $CONDA_DIR && \
|
||||||
rm Miniconda3-${MINICONDA_VERSION}-Linux-x86_64.sh && \
|
rm Miniconda3-py37_${MINICONDA_VERSION}-Linux-x86_64.sh && \
|
||||||
echo "conda ${CONDA_VERSION}" >> $CONDA_DIR/conda-meta/pinned && \
|
echo "conda ${CONDA_VERSION}" >> $CONDA_DIR/conda-meta/pinned && \
|
||||||
conda config --system --prepend channels conda-forge && \
|
conda config --system --prepend channels conda-forge && \
|
||||||
conda config --system --set auto_update_conda false && \
|
conda config --system --set auto_update_conda false && \
|
||||||
conda config --system --set show_channel_urls true && \
|
conda config --system --set show_channel_urls true && \
|
||||||
|
conda config --system --set channel_priority strict && \
|
||||||
if [ ! $PYTHON_VERSION = 'default' ]; then conda install --yes python=$PYTHON_VERSION; fi && \
|
if [ ! $PYTHON_VERSION = 'default' ]; then conda install --yes python=$PYTHON_VERSION; fi && \
|
||||||
conda list python | grep '^python ' | tr -s ' ' | cut -d '.' -f 1,2 | sed 's/$/.*/' >> $CONDA_DIR/conda-meta/pinned && \
|
conda list python | grep '^python ' | tr -s ' ' | cut -d '.' -f 1,2 | sed 's/$/.*/' >> $CONDA_DIR/conda-meta/pinned && \
|
||||||
conda install --quiet --yes conda && \
|
conda install --quiet --yes conda && \
|
||||||
@ -118,7 +123,7 @@ RUN conda install --quiet --yes 'tini=0.18.0' && \
|
|||||||
RUN conda install --quiet --yes \
|
RUN conda install --quiet --yes \
|
||||||
'notebook=6.0.3' \
|
'notebook=6.0.3' \
|
||||||
'jupyterhub=1.1.0' \
|
'jupyterhub=1.1.0' \
|
||||||
'jupyterlab=1.2.5' && \
|
'jupyterlab=2.1.3' && \
|
||||||
conda clean --all -f -y && \
|
conda clean --all -f -y && \
|
||||||
npm cache clean --force && \
|
npm cache clean --force && \
|
||||||
jupyter notebook --generate-config && \
|
jupyter notebook --generate-config && \
|
||||||
@ -134,9 +139,7 @@ ENTRYPOINT ["tini", "-g", "--"]
|
|||||||
CMD ["start-notebook.sh"]
|
CMD ["start-notebook.sh"]
|
||||||
|
|
||||||
# Copy local files as late as possible to avoid cache busting
|
# Copy local files as late as possible to avoid cache busting
|
||||||
COPY start.sh /usr/local/bin/
|
COPY start.sh start-notebook.sh start-singleuser.sh /usr/local/bin/
|
||||||
COPY start-notebook.sh /usr/local/bin/
|
|
||||||
COPY start-singleuser.sh /usr/local/bin/
|
|
||||||
COPY jupyter_notebook_config.py /etc/jupyter/
|
COPY jupyter_notebook_config.py /etc/jupyter/
|
||||||
|
|
||||||
# Fix permissions on /etc/jupyter as root
|
# Fix permissions on /etc/jupyter as root
|
||||||
@ -146,6 +149,8 @@ RUN fix-permissions /etc/jupyter/
|
|||||||
# Switch back to jovyan to avoid accidental container runs as root
|
# Switch back to jovyan to avoid accidental container runs as root
|
||||||
USER $NB_UID
|
USER $NB_UID
|
||||||
|
|
||||||
|
WORKDIR $HOME
|
||||||
|
|
||||||
############################################################################
|
############################################################################
|
||||||
################# Dependency: jupyter/minimal-notebook #####################
|
################# Dependency: jupyter/minimal-notebook #####################
|
||||||
############################################################################
|
############################################################################
|
||||||
@ -160,7 +165,8 @@ USER root
|
|||||||
# Install all OS dependencies for fully functional notebook server
|
# Install all OS dependencies for fully functional notebook server
|
||||||
RUN apt-get update && apt-get install -yq --no-install-recommends \
|
RUN apt-get update && apt-get install -yq --no-install-recommends \
|
||||||
build-essential \
|
build-essential \
|
||||||
emacs \
|
emacs-nox \
|
||||||
|
vim-tiny \
|
||||||
git \
|
git \
|
||||||
inkscape \
|
inkscape \
|
||||||
jed \
|
jed \
|
||||||
@ -173,7 +179,7 @@ RUN apt-get update && apt-get install -yq --no-install-recommends \
|
|||||||
# ---- nbconvert dependencies ----
|
# ---- nbconvert dependencies ----
|
||||||
texlive-xetex \
|
texlive-xetex \
|
||||||
texlive-fonts-recommended \
|
texlive-fonts-recommended \
|
||||||
texlive-generic-recommended \
|
texlive-plain-generic \
|
||||||
# Optional dependency
|
# Optional dependency
|
||||||
texlive-fonts-extra \
|
texlive-fonts-extra \
|
||||||
# ----
|
# ----
|
||||||
@ -196,40 +202,45 @@ LABEL maintainer="Jupyter Project <jupyter@googlegroups.com>"
|
|||||||
|
|
||||||
USER root
|
USER root
|
||||||
|
|
||||||
# ffmpeg for matplotlib anim
|
# ffmpeg for matplotlib anim & dvipng for latex labels
|
||||||
RUN apt-get update && \
|
RUN apt-get update && \
|
||||||
apt-get install -y --no-install-recommends ffmpeg && \
|
apt-get install -y --no-install-recommends ffmpeg dvipng && \
|
||||||
rm -rf /var/lib/apt/lists/*
|
rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
USER $NB_UID
|
USER $NB_UID
|
||||||
|
|
||||||
# Install Python 3 packages
|
# Install Python 3 packages
|
||||||
RUN conda install --quiet --yes \
|
RUN conda install --quiet --yes \
|
||||||
'beautifulsoup4=4.8.*' \
|
'beautifulsoup4=4.9.*' \
|
||||||
'conda-forge::blas=*=openblas' \
|
'conda-forge::blas=*=openblas' \
|
||||||
'bokeh=1.4.*' \
|
'bokeh=2.0.*' \
|
||||||
'cloudpickle=1.2.*' \
|
'bottleneck=1.3.*' \
|
||||||
|
'cloudpickle=1.4.*' \
|
||||||
'cython=0.29.*' \
|
'cython=0.29.*' \
|
||||||
'dask=2.9.*' \
|
'dask=2.15.*' \
|
||||||
'dill=0.3.*' \
|
'dill=0.3.*' \
|
||||||
'h5py=2.10.*' \
|
'h5py=2.10.*' \
|
||||||
'hdf5=1.10.*' \
|
'hdf5=1.10.*' \
|
||||||
'ipywidgets=7.5.*' \
|
'ipywidgets=7.5.*' \
|
||||||
'matplotlib-base=3.1.*' \
|
'ipympl=0.5.*'\
|
||||||
|
'matplotlib-base=3.2.*' \
|
||||||
|
# numba update to 0.49 fails resolving deps.
|
||||||
'numba=0.48.*' \
|
'numba=0.48.*' \
|
||||||
'numexpr=2.7.*' \
|
'numexpr=2.7.*' \
|
||||||
'pandas=0.25.*' \
|
'pandas=1.0.*' \
|
||||||
'patsy=0.5.*' \
|
'patsy=0.5.*' \
|
||||||
'protobuf=3.11.*' \
|
'protobuf=3.11.*' \
|
||||||
|
'pytables=3.6.*' \
|
||||||
'scikit-image=0.16.*' \
|
'scikit-image=0.16.*' \
|
||||||
'scikit-learn=0.22.*' \
|
'scikit-learn=0.22.*' \
|
||||||
'scipy=1.4.*' \
|
'scipy=1.4.*' \
|
||||||
'seaborn=0.9.*' \
|
'seaborn=0.10.*' \
|
||||||
'sqlalchemy=1.3.*' \
|
'sqlalchemy=1.3.*' \
|
||||||
'statsmodels=0.11.*' \
|
'statsmodels=0.11.*' \
|
||||||
'sympy=1.5.*' \
|
'sympy=1.5.*' \
|
||||||
'vincent=0.4.*' \
|
'vincent=0.4.*' \
|
||||||
'xlrd' \
|
'widgetsnbextension=3.5.*'\
|
||||||
|
'xlrd=1.2.*' \
|
||||||
&& \
|
&& \
|
||||||
conda clean --all -f -y && \
|
conda clean --all -f -y && \
|
||||||
# Activate ipywidgets extension in the environment that runs the notebook server
|
# Activate ipywidgets extension in the environment that runs the notebook server
|
||||||
@ -237,121 +248,34 @@ RUN conda install --quiet --yes \
|
|||||||
# Also activate ipywidgets extension for JupyterLab
|
# Also activate ipywidgets extension for JupyterLab
|
||||||
# Check this URL for most recent compatibilities
|
# Check this URL for most recent compatibilities
|
||||||
# https://github.com/jupyter-widgets/ipywidgets/tree/master/packages/jupyterlab-manager
|
# https://github.com/jupyter-widgets/ipywidgets/tree/master/packages/jupyterlab-manager
|
||||||
jupyter labextension install @jupyter-widgets/jupyterlab-manager@^1.0.1 --no-build && \
|
jupyter labextension install @jupyter-widgets/jupyterlab-manager@^2.0.0 --no-build && \
|
||||||
jupyter labextension install jupyterlab_bokeh@1.0.0 --no-build && \
|
jupyter labextension install @bokeh/jupyter_bokeh@^2.0.0 --no-build && \
|
||||||
jupyter lab build && \
|
jupyter labextension install jupyter-matplotlib@^0.7.2 --no-build && \
|
||||||
|
jupyter lab build -y && \
|
||||||
|
jupyter lab clean -y && \
|
||||||
npm cache clean --force && \
|
npm cache clean --force && \
|
||||||
rm -rf $CONDA_DIR/share/jupyter/lab/staging && \
|
rm -rf "/home/${NB_USER}/.cache/yarn" && \
|
||||||
rm -rf /home/$NB_USER/.cache/yarn && \
|
rm -rf "/home/${NB_USER}/.node-gyp" && \
|
||||||
rm -rf /home/$NB_USER/.node-gyp && \
|
fix-permissions "${CONDA_DIR}" && \
|
||||||
fix-permissions $CONDA_DIR && \
|
fix-permissions "/home/${NB_USER}"
|
||||||
fix-permissions /home/$NB_USER
|
|
||||||
|
|
||||||
# Install facets which does not have a pip or conda package at the moment
|
# Install facets which does not have a pip or conda package at the moment
|
||||||
RUN cd /tmp && \
|
WORKDIR /tmp
|
||||||
git clone https://github.com/PAIR-code/facets.git && \
|
RUN git clone https://github.com/PAIR-code/facets.git && \
|
||||||
cd facets && \
|
jupyter nbextension install facets/facets-dist/ --sys-prefix && \
|
||||||
jupyter nbextension install facets-dist/ --sys-prefix && \
|
|
||||||
cd && \
|
|
||||||
rm -rf /tmp/facets && \
|
rm -rf /tmp/facets && \
|
||||||
fix-permissions $CONDA_DIR && \
|
fix-permissions "${CONDA_DIR}" && \
|
||||||
fix-permissions /home/$NB_USER
|
fix-permissions "/home/${NB_USER}"
|
||||||
|
|
||||||
# Import matplotlib the first time to build the font cache.
|
# Import matplotlib the first time to build the font cache.
|
||||||
ENV XDG_CACHE_HOME /home/$NB_USER/.cache/
|
ENV XDG_CACHE_HOME="/home/${NB_USER}/.cache/"
|
||||||
|
|
||||||
RUN MPLBACKEND=Agg python -c "import matplotlib.pyplot" && \
|
RUN MPLBACKEND=Agg python -c "import matplotlib.pyplot" && \
|
||||||
fix-permissions /home/$NB_USER
|
fix-permissions "/home/${NB_USER}"
|
||||||
|
|
||||||
USER $NB_UID
|
USER $NB_UID
|
||||||
|
|
||||||
############################################################################
|
WORKDIR $HOME
|
||||||
################ Dependency: jupyter/datascience-notebook ##################
|
|
||||||
############################################################################
|
|
||||||
|
|
||||||
# Copyright (c) Jupyter Development Team.
|
|
||||||
# Distributed under the terms of the Modified BSD License.
|
|
||||||
|
|
||||||
LABEL maintainer="Jupyter Project <jupyter@googlegroups.com>"
|
|
||||||
|
|
||||||
# Set when building on Travis so that certain long-running build steps can
|
|
||||||
# be skipped to shorten build time.
|
|
||||||
ARG TEST_ONLY_BUILD
|
|
||||||
|
|
||||||
USER root
|
|
||||||
|
|
||||||
# R pre-requisites
|
|
||||||
RUN apt-get update && \
|
|
||||||
apt-get install -y --no-install-recommends \
|
|
||||||
fonts-dejavu \
|
|
||||||
gfortran \
|
|
||||||
gcc && \
|
|
||||||
rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
# Julia dependencies
|
|
||||||
# install Julia packages in /opt/julia instead of $HOME
|
|
||||||
ENV JULIA_DEPOT_PATH=/opt/julia
|
|
||||||
ENV JULIA_PKGDIR=/opt/julia
|
|
||||||
ENV JULIA_VERSION=1.3.1
|
|
||||||
|
|
||||||
RUN mkdir /opt/julia-${JULIA_VERSION} && \
|
|
||||||
cd /tmp && \
|
|
||||||
wget -q https://julialang-s3.julialang.org/bin/linux/x64/`echo ${JULIA_VERSION} | cut -d. -f 1,2`/julia-${JULIA_VERSION}-linux-x86_64.tar.gz && \
|
|
||||||
echo "faa707c8343780a6fe5eaf13490355e8190acf8e2c189b9e7ecbddb0fa2643ad *julia-${JULIA_VERSION}-linux-x86_64.tar.gz" | sha256sum -c - && \
|
|
||||||
tar xzf julia-${JULIA_VERSION}-linux-x86_64.tar.gz -C /opt/julia-${JULIA_VERSION} --strip-components=1 && \
|
|
||||||
rm /tmp/julia-${JULIA_VERSION}-linux-x86_64.tar.gz
|
|
||||||
RUN ln -fs /opt/julia-*/bin/julia /usr/local/bin/julia
|
|
||||||
|
|
||||||
# Show Julia where conda libraries are \
|
|
||||||
RUN mkdir /etc/julia && \
|
|
||||||
echo "push!(Libdl.DL_LOAD_PATH, \"$CONDA_DIR/lib\")" >> /etc/julia/juliarc.jl && \
|
|
||||||
# Create JULIA_PKGDIR \
|
|
||||||
mkdir $JULIA_PKGDIR && \
|
|
||||||
chown $NB_USER $JULIA_PKGDIR && \
|
|
||||||
fix-permissions $JULIA_PKGDIR
|
|
||||||
|
|
||||||
USER $NB_UID
|
|
||||||
|
|
||||||
# R packages including IRKernel which gets installed globally.
|
|
||||||
RUN conda install --quiet --yes \
|
|
||||||
'r-base=3.6.2' \
|
|
||||||
'r-caret=6.0*' \
|
|
||||||
'r-crayon=1.3*' \
|
|
||||||
'r-devtools=2.2*' \
|
|
||||||
'r-forecast=8.10*' \
|
|
||||||
'r-hexbin=1.28*' \
|
|
||||||
'r-htmltools=0.4*' \
|
|
||||||
'r-htmlwidgets=1.5*' \
|
|
||||||
'r-irkernel=1.1*' \
|
|
||||||
'r-nycflights13=1.0*' \
|
|
||||||
'r-plyr=1.8*' \
|
|
||||||
'r-randomforest=4.6*' \
|
|
||||||
'r-rcurl=1.98*' \
|
|
||||||
'r-reshape2=1.4*' \
|
|
||||||
'r-rmarkdown=2.1*' \
|
|
||||||
'r-rsqlite=2.1*' \
|
|
||||||
'r-shiny=1.3*' \
|
|
||||||
'r-tidyverse=1.3*' \
|
|
||||||
'rpy2=3.1*' \
|
|
||||||
&& \
|
|
||||||
conda clean --all -f -y && \
|
|
||||||
fix-permissions $CONDA_DIR && \
|
|
||||||
fix-permissions /home/$NB_USER
|
|
||||||
|
|
||||||
# Add Julia packages. Only add HDF5 if this is not a test-only build since
|
|
||||||
# it takes roughly half the entire build time of all of the images on Travis
|
|
||||||
# to add this one package and often causes Travis to timeout.
|
|
||||||
#
|
|
||||||
# Install IJulia as jovyan and then move the kernelspec out
|
|
||||||
# to the system share location. Avoids problems with runtime UID change not
|
|
||||||
# taking effect properly on the .local folder in the jovyan home dir.
|
|
||||||
RUN julia -e 'import Pkg; Pkg.update()' && \
|
|
||||||
(test $TEST_ONLY_BUILD || julia -e 'import Pkg; Pkg.add("HDF5")') && \
|
|
||||||
julia -e "using Pkg; pkg\"add IJulia\"; pkg\"precompile\"" && \
|
|
||||||
# move kernelspec out of home \
|
|
||||||
mv $HOME/.local/share/jupyter/kernels/julia* $CONDA_DIR/share/jupyter/kernels/ && \
|
|
||||||
chmod -R go+rx $CONDA_DIR/share/jupyter && \
|
|
||||||
rm -rf $HOME/.local && \
|
|
||||||
fix-permissions $JULIA_PKGDIR $CONDA_DIR/share/jupyter
|
|
||||||
|
|
||||||
############################################################################
|
############################################################################
|
||||||
########################## Dependency: gpulibs #############################
|
########################## Dependency: gpulibs #############################
|
||||||
@ -360,11 +284,15 @@ RUN julia -e 'import Pkg; Pkg.update()' && \
|
|||||||
LABEL maintainer="Christoph Schranz <christoph.schranz@salzburgresearch.at>"
|
LABEL maintainer="Christoph Schranz <christoph.schranz@salzburgresearch.at>"
|
||||||
|
|
||||||
# Install Tensorflow, check compatibility here: https://www.tensorflow.org/install/gpu
|
# Install Tensorflow, check compatibility here: https://www.tensorflow.org/install/gpu
|
||||||
RUN conda install --quiet --yes \
|
# installation via conda leads to errors in version 4.8.2
|
||||||
'tensorflow-gpu=2.1*' \
|
#RUN conda install --quiet --yes \
|
||||||
'keras-gpu' && \
|
# 'tensorflow-gpu=2.1*' \
|
||||||
fix-permissions $CONDA_DIR && \
|
# 'keras-gpu' && \
|
||||||
fix-permissions /home/$NB_USER
|
# fix-permissions $CONDA_DIR && \
|
||||||
|
# fix-permissions /home/$NB_USER
|
||||||
|
RUN pip install --upgrade pip && \
|
||||||
|
pip install --no-cache-dir "tensorflow-gpu>=2.1.*" && \
|
||||||
|
pip install --no-cache-dir keras
|
||||||
|
|
||||||
# Install PyTorch with dependencies
|
# Install PyTorch with dependencies
|
||||||
RUN conda install --quiet --yes \
|
RUN conda install --quiet --yes \
|
||||||
@ -382,57 +310,5 @@ RUN conda clean --all -f -y && \
|
|||||||
fix-permissions $CONDA_DIR && \
|
fix-permissions $CONDA_DIR && \
|
||||||
fix-permissions /home/$NB_USER
|
fix-permissions /home/$NB_USER
|
||||||
|
|
||||||
############################################################################
|
|
||||||
############################ Useful packages ###############################
|
|
||||||
############################################################################
|
|
||||||
|
|
||||||
LABEL maintainer="Christoph Schranz <christoph.schranz@salzburgresearch.at>"
|
|
||||||
|
|
||||||
# Update conda
|
|
||||||
RUN conda update -n base conda -y
|
|
||||||
|
|
||||||
USER root
|
|
||||||
|
|
||||||
# Install elasticsearch libs
|
|
||||||
USER root
|
|
||||||
RUN apt-get update \
|
|
||||||
&& curl -sL https://repo1.maven.org/maven2/org/elasticsearch/elasticsearch-hadoop/6.8.1/elasticsearch-hadoop-6.8.1.jar
|
|
||||||
RUN pip install --no-cache-dir elasticsearch==7.1.0
|
|
||||||
|
|
||||||
# Install rpy2 to share data between Python and R
|
|
||||||
RUN conda install rpy2=2.9.4 plotly=4.4.1
|
|
||||||
RUN conda install -c conda-forge ipyleaflet
|
|
||||||
|
|
||||||
# Install important packages and Graphviz
|
|
||||||
RUN set -ex \
|
|
||||||
&& buildDeps=' \
|
|
||||||
graphviz==0.11 \
|
|
||||||
' \
|
|
||||||
&& apt-get update \
|
|
||||||
&& apt-get -y install htop apt-utils graphviz libgraphviz-dev \
|
|
||||||
&& pip install --no-cache-dir $buildDeps
|
|
||||||
|
|
||||||
# Install various extensions
|
|
||||||
RUN jupyter labextension install @jupyterlab/github
|
|
||||||
RUN jupyter labextension install jupyterlab-drawio
|
|
||||||
RUN jupyter labextension install jupyter-leaflet
|
|
||||||
RUN jupyter labextension install @jupyterlab/plotly-extension
|
|
||||||
RUN jupyter labextension install @jupyter-widgets/jupyterlab-manager
|
|
||||||
RUN pip install --no-cache-dir jupyter-tabnine==1.0.2 && \
|
|
||||||
jupyter nbextension install --py jupyter_tabnine && \
|
|
||||||
jupyter nbextension enable --py jupyter_tabnine && \
|
|
||||||
jupyter serverextension enable --py jupyter_tabnine
|
|
||||||
RUN fix-permissions $CONDA_DIR
|
|
||||||
RUN conda install -c conda-forge jupyter_contrib_nbextensions && \
|
|
||||||
conda install -c conda-forge jupyter_nbextensions_configurator && \
|
|
||||||
conda install -c conda-forge rise && \
|
|
||||||
jupyter nbextension enable codefolding/main
|
|
||||||
RUN jupyter labextension install @ijmbarr/jupyterlab_spellchecker
|
|
||||||
|
|
||||||
RUN fix-permissions /home/$NB_USER
|
|
||||||
|
|
||||||
# Switch back to jovyan to avoid accidental container runs as root
|
|
||||||
USER $NB_UID
|
|
||||||
|
|
||||||
# Copy jupyter_notebook_config.json
|
# Copy jupyter_notebook_config.json
|
||||||
COPY jupyter_notebook_config.json /etc/jupyter/
|
COPY jupyter_notebook_config.json /etc/jupyter/
|
||||||
|
@ -1 +1 @@
|
|||||||
Subproject commit c1c32938438151c7e2a22b5aa338caba2ec01da2
|
Subproject commit 04f7f60d34a674a2964d96a6cb97c57a7870a828
|
@ -6,14 +6,14 @@ set -e
|
|||||||
|
|
||||||
wrapper=""
|
wrapper=""
|
||||||
if [[ "${RESTARTABLE}" == "yes" ]]; then
|
if [[ "${RESTARTABLE}" == "yes" ]]; then
|
||||||
wrapper="run-one-constantly"
|
wrapper="run-one-constantly"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ ! -z "${JUPYTERHUB_API_TOKEN}" ]]; then
|
if [[ ! -z "${JUPYTERHUB_API_TOKEN}" ]]; then
|
||||||
# launched by JupyterHub, use single-user entrypoint
|
# launched by JupyterHub, use single-user entrypoint
|
||||||
exec /usr/local/bin/start-singleuser.sh "$@"
|
exec /usr/local/bin/start-singleuser.sh "$@"
|
||||||
elif [[ ! -z "${JUPYTER_ENABLE_LAB}" ]]; then
|
elif [[ ! -z "${JUPYTER_ENABLE_LAB}" ]]; then
|
||||||
. /usr/local/bin/start.sh $wrapper jupyter lab "$@"
|
. /usr/local/bin/start.sh $wrapper jupyter lab "$@"
|
||||||
else
|
else
|
||||||
. /usr/local/bin/start.sh $wrapper jupyter notebook "$@"
|
. /usr/local/bin/start.sh $wrapper jupyter notebook "$@"
|
||||||
fi
|
fi
|
||||||
|
@ -6,7 +6,7 @@ set -e
|
|||||||
|
|
||||||
# set default ip to 0.0.0.0
|
# set default ip to 0.0.0.0
|
||||||
if [[ "$NOTEBOOK_ARGS $@" != *"--ip="* ]]; then
|
if [[ "$NOTEBOOK_ARGS $@" != *"--ip="* ]]; then
|
||||||
NOTEBOOK_ARGS="--ip=0.0.0.0 $NOTEBOOK_ARGS"
|
NOTEBOOK_ARGS="--ip=0.0.0.0 $NOTEBOOK_ARGS"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# handle some deprecated environment variables
|
# handle some deprecated environment variables
|
||||||
@ -14,30 +14,26 @@ fi
|
|||||||
# These won't be passed from DockerSpawner 0.9,
|
# These won't be passed from DockerSpawner 0.9,
|
||||||
# so avoid specifying --arg=empty-string
|
# so avoid specifying --arg=empty-string
|
||||||
if [ ! -z "$NOTEBOOK_DIR" ]; then
|
if [ ! -z "$NOTEBOOK_DIR" ]; then
|
||||||
NOTEBOOK_ARGS="--notebook-dir='$NOTEBOOK_DIR' $NOTEBOOK_ARGS"
|
NOTEBOOK_ARGS="--notebook-dir='$NOTEBOOK_DIR' $NOTEBOOK_ARGS"
|
||||||
fi
|
fi
|
||||||
if [ ! -z "$JPY_PORT" ]; then
|
if [ ! -z "$JPY_PORT" ]; then
|
||||||
NOTEBOOK_ARGS="--port=$JPY_PORT $NOTEBOOK_ARGS"
|
NOTEBOOK_ARGS="--port=$JPY_PORT $NOTEBOOK_ARGS"
|
||||||
fi
|
fi
|
||||||
if [ ! -z "$JPY_USER" ]; then
|
if [ ! -z "$JPY_USER" ]; then
|
||||||
NOTEBOOK_ARGS="--user=$JPY_USER $NOTEBOOK_ARGS"
|
NOTEBOOK_ARGS="--user=$JPY_USER $NOTEBOOK_ARGS"
|
||||||
fi
|
fi
|
||||||
if [ ! -z "$JPY_COOKIE_NAME" ]; then
|
if [ ! -z "$JPY_COOKIE_NAME" ]; then
|
||||||
NOTEBOOK_ARGS="--cookie-name=$JPY_COOKIE_NAME $NOTEBOOK_ARGS"
|
NOTEBOOK_ARGS="--cookie-name=$JPY_COOKIE_NAME $NOTEBOOK_ARGS"
|
||||||
fi
|
fi
|
||||||
if [ ! -z "$JPY_BASE_URL" ]; then
|
if [ ! -z "$JPY_BASE_URL" ]; then
|
||||||
NOTEBOOK_ARGS="--base-url=$JPY_BASE_URL $NOTEBOOK_ARGS"
|
NOTEBOOK_ARGS="--base-url=$JPY_BASE_URL $NOTEBOOK_ARGS"
|
||||||
fi
|
fi
|
||||||
if [ ! -z "$JPY_HUB_PREFIX" ]; then
|
if [ ! -z "$JPY_HUB_PREFIX" ]; then
|
||||||
NOTEBOOK_ARGS="--hub-prefix=$JPY_HUB_PREFIX $NOTEBOOK_ARGS"
|
NOTEBOOK_ARGS="--hub-prefix=$JPY_HUB_PREFIX $NOTEBOOK_ARGS"
|
||||||
fi
|
fi
|
||||||
if [ ! -z "$JPY_HUB_API_URL" ]; then
|
if [ ! -z "$JPY_HUB_API_URL" ]; then
|
||||||
NOTEBOOK_ARGS="--hub-api-url=$JPY_HUB_API_URL $NOTEBOOK_ARGS"
|
NOTEBOOK_ARGS="--hub-api-url=$JPY_HUB_API_URL $NOTEBOOK_ARGS"
|
||||||
fi
|
|
||||||
if [ ! -z "$JUPYTER_ENABLE_LAB" ]; then
|
|
||||||
NOTEBOOK_BIN="jupyter labhub"
|
|
||||||
else
|
|
||||||
NOTEBOOK_BIN="jupyterhub-singleuser"
|
|
||||||
fi
|
fi
|
||||||
|
NOTEBOOK_BIN="jupyterhub-singleuser"
|
||||||
|
|
||||||
. /usr/local/bin/start.sh $NOTEBOOK_BIN $NOTEBOOK_ARGS "$@"
|
. /usr/local/bin/start.sh $NOTEBOOK_BIN $NOTEBOOK_ARGS "$@"
|
||||||
|
@ -93,7 +93,7 @@ if [ $(id -u) == 0 ] ; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Add $CONDA_DIR/bin to sudo secure_path
|
# Add $CONDA_DIR/bin to sudo secure_path
|
||||||
sed -r "s#Defaults\s+secure_path=\"([^\"]+)\"#Defaults secure_path=\"\1:$CONDA_DIR/bin\"#" /etc/sudoers | grep secure_path > /etc/sudoers.d/path
|
sed -r "s#Defaults\s+secure_path\s*=\s*\"?([^\"]+)\"?#Defaults secure_path=\"\1:$CONDA_DIR/bin\"#" /etc/sudoers | grep secure_path > /etc/sudoers.d/path
|
||||||
|
|
||||||
# Exec the command as NB_USER with the PATH and the rest of
|
# Exec the command as NB_USER with the PATH and the rest of
|
||||||
# the environment preserved
|
# the environment preserved
|
||||||
|
79
README.md
79
README.md
@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
First of all, thanks to [docker-stacks](https://github.com/jupyter/docker-stacks)
|
First of all, thanks to [docker-stacks](https://github.com/jupyter/docker-stacks)
|
||||||
for creating and maintaining a robost Python, R and Julia toolstack for Data Analytics/Science
|
for creating and maintaining a robost Python, R and Julia toolstack for Data Analytics/Science
|
||||||
applications. This project uses the NVIDIA CUDA image as a basis image and installs their
|
applications. This project uses the NVIDIA CUDA image as the base image and installs their
|
||||||
toolstack on top of it to enable GPU calculations in the Jupyter notebooks.
|
toolstack on top of it to enable GPU calculations in the Jupyter notebooks.
|
||||||
The image of this repository is available on [Dockerhub](https://hub.docker.com/r/cschranz/gpu-jupyter).
|
The image of this repository is available on [Dockerhub](https://hub.docker.com/r/cschranz/gpu-jupyter).
|
||||||
|
|
||||||
@ -21,13 +21,34 @@ The image of this repository is available on [Dockerhub](https://hub.docker.com/
|
|||||||
|
|
||||||
## Requirements
|
## Requirements
|
||||||
|
|
||||||
1. Install [Docker](https://www.docker.com/community-edition#/download) version **1.10.0+**
|
1. A NVIDIA GPU
|
||||||
|
2. Install [Docker](https://www.docker.com/community-edition#/download) version **1.10.0+**
|
||||||
and [Docker Compose](https://docs.docker.com/compose/install/) version **1.6.0+**.
|
and [Docker Compose](https://docs.docker.com/compose/install/) version **1.6.0+**.
|
||||||
2. A NVIDIA GPU
|
3. Get access to your GPU via CUDA drivers within Docker containers. Therfore, check out this
|
||||||
3. Get access to use your GPU via the CUDA drivers, check out this
|
|
||||||
[medium article](https://medium.com/@christoph.schranz/set-up-your-own-gpu-based-jupyterlab-e0d45fcacf43).
|
[medium article](https://medium.com/@christoph.schranz/set-up-your-own-gpu-based-jupyterlab-e0d45fcacf43).
|
||||||
The CUDA toolkit is not required on the host system, as it will be deployed
|
The CUDA toolkit is not required on the host system, as it will be deployed
|
||||||
in [NVIDIA-docker](https://github.com/NVIDIA/nvidia-docker).
|
in [NVIDIA-docker](https://github.com/NVIDIA/nvidia-docker).
|
||||||
|
You can be sure that you can access your GPU within Docker,
|
||||||
|
if the command `docker run --runtime nvidia nvidia/cuda:10.1-base-ubuntu18.04 nvidia-smi`
|
||||||
|
returns a result similar to this one:
|
||||||
|
```bash
|
||||||
|
Mon Jun 22 09:06:28 2020
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
| NVIDIA-SMI 440.82 Driver Version: 440.82 CUDA Version: 10.1 |
|
||||||
|
|-------------------------------+----------------------+----------------------+
|
||||||
|
| GPU Name Persistence-M| Bus-Id Disp.A | Volatile Uncorr. ECC |
|
||||||
|
| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M. |
|
||||||
|
|===============================+======================+======================|
|
||||||
|
| 0 GeForce RTX 207... Off | 00000000:01:00.0 On | N/A |
|
||||||
|
| 0% 46C P8 9W / 215W | 424MiB / 7974MiB | 6% Default |
|
||||||
|
+-------------------------------+----------------------+----------------------+
|
||||||
|
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
| Processes: GPU Memory |
|
||||||
|
| GPU PID Type Process name Usage |
|
||||||
|
|=============================================================================|
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
```
|
||||||
4. Clone the Repository or pull the image from
|
4. Clone the Repository or pull the image from
|
||||||
[Dockerhub](https://hub.docker.com/repository/docker/cschranz/gpu-jupyter):
|
[Dockerhub](https://hub.docker.com/repository/docker/cschranz/gpu-jupyter):
|
||||||
```bash
|
```bash
|
||||||
@ -37,30 +58,46 @@ The image of this repository is available on [Dockerhub](https://hub.docker.com/
|
|||||||
|
|
||||||
## Quickstart
|
## Quickstart
|
||||||
|
|
||||||
First of all, it is necessary to generate the `Dockerfile` based on the latest toolstack of
|
First of all, it is necessary to generate the `Dockerfile` based on the
|
||||||
[hub.docker.com/u/jupyter](https://hub.docker.com/u/jupyter).
|
[docker-stacks](https://github.com/jupyter/docker-stacks).
|
||||||
As soon as you have access to your GPU locally (it can be tested via a Tensorflow or PyTorch
|
As soon as you have access to your GPU within Docker containers
|
||||||
directly on the host node), you can run these commands to start the jupyter notebook via
|
(make sure the command `docker run --runtime nvidia nvidia/cuda:10.1-base-ubuntu18.04 nvidia-smi` shows your
|
||||||
docker-compose (internally):
|
GPU statistics), you can generate a Dockerfile and build it via docker-compose.
|
||||||
|
The two commands will start *GPU-Jupyter* on [localhost:1234](http://localhost:1234) with the default
|
||||||
|
password `asdf`.
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
./generate-Dockerfile.sh
|
./generate-Dockerfile.sh
|
||||||
|
./start-local.sh -p 1234 # where -p stands for the port, default 8888
|
||||||
|
```
|
||||||
|
|
||||||
|
## Parameter
|
||||||
|
|
||||||
|
The script `generate-Dockerfile.sh` has multiple parameters:
|
||||||
|
|
||||||
|
* `-c|--commit`: specify a commit or `"latest"` for the `docker-stacks`, the default commit is a working one.
|
||||||
|
|
||||||
|
* `-s|--slim`: Generate a slim Dockerfile.
|
||||||
|
As some installations are not needed by everyone, there is the possibility to skip some installations
|
||||||
|
to reduce the size of the image.
|
||||||
|
Here the `docker-stack` `scipy-notebook` is used instead of `datascience-notebook` that comes with Julia and R.
|
||||||
|
Moreover, none of the packages within `src/Dockerfile.usefulpackages` is installed.
|
||||||
|
|
||||||
|
* `--no-datascience-notebook`: As the name suggests, the `docker-stack` `datascience-notebook` is not installed
|
||||||
|
on top of the `scipy-notebook`, but the packages within `src/Dockerfile.usefulpackages` are.
|
||||||
|
|
||||||
|
* `--no-useful-packages`: On top of the `docker-stack` `datascience-notebook`, the essential `gpulibs` are installed
|
||||||
|
but not the packages within `src/Dockerfile.usefulpackages`.
|
||||||
|
|
||||||
|
|
||||||
|
The script `start-local.sh` is a wrapper for a quick configuration of the underlying `docker-compose.yml`.
|
||||||
|
It is equal to these commands:
|
||||||
|
|
||||||
|
```bash
|
||||||
docker build -t gpu-jupyter .build/
|
docker build -t gpu-jupyter .build/
|
||||||
docker run -d -p [port]:8888 gpu-jupyter
|
docker run -d -p [port]:8888 gpu-jupyter
|
||||||
```
|
```
|
||||||
|
|
||||||
Alternatively, you can configure the environment in `docker-compose.yml` and run
|
|
||||||
this to deploy the `GPU-Jupyter` via docker-compose (under-the-hood):
|
|
||||||
|
|
||||||
```bash
|
|
||||||
./generate-Dockerfile.sh
|
|
||||||
./start-local.sh -p 8888 # where -p stands for the port of the service
|
|
||||||
```
|
|
||||||
|
|
||||||
Both options will run *GPU-Jupyter* by default on [localhost:8888](http://localhost:8888) with the default
|
|
||||||
password `asdf`.
|
|
||||||
|
|
||||||
|
|
||||||
## Tracing
|
## Tracing
|
||||||
|
|
||||||
With these commands we can see if everything worked well:
|
With these commands we can see if everything worked well:
|
||||||
|
@ -27,15 +27,15 @@
|
|||||||
"name": "stdout",
|
"name": "stdout",
|
||||||
"output_type": "stream",
|
"output_type": "stream",
|
||||||
"text": [
|
"text": [
|
||||||
"Wed Mar 11 07:16:17 2020 \n",
|
"Mon Jun 22 11:24:08 2020 \n",
|
||||||
"+-----------------------------------------------------------------------------+\n",
|
"+-----------------------------------------------------------------------------+\n",
|
||||||
"| NVIDIA-SMI 440.48.02 Driver Version: 440.48.02 CUDA Version: 10.2 |\n",
|
"| NVIDIA-SMI 440.82 Driver Version: 440.82 CUDA Version: 10.2 |\n",
|
||||||
"|-------------------------------+----------------------+----------------------+\n",
|
"|-------------------------------+----------------------+----------------------+\n",
|
||||||
"| GPU Name Persistence-M| Bus-Id Disp.A | Volatile Uncorr. ECC |\n",
|
"| GPU Name Persistence-M| Bus-Id Disp.A | Volatile Uncorr. ECC |\n",
|
||||||
"| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M. |\n",
|
"| Fan Temp Perf Pwr:Usage/Cap| Memory-Usage | GPU-Util Compute M. |\n",
|
||||||
"|===============================+======================+======================|\n",
|
"|===============================+======================+======================|\n",
|
||||||
"| 0 GeForce RTX 207... Off | 00000000:01:00.0 Off | N/A |\n",
|
"| 0 GeForce RTX 207... Off | 00000000:01:00.0 On | N/A |\n",
|
||||||
"| 0% 42C P8 1W / 215W | 1788MiB / 7974MiB | 0% Default |\n",
|
"| 0% 49C P0 38W / 215W | 430MiB / 7974MiB | 5% Default |\n",
|
||||||
"+-------------------------------+----------------------+----------------------+\n",
|
"+-------------------------------+----------------------+----------------------+\n",
|
||||||
" \n",
|
" \n",
|
||||||
"+-----------------------------------------------------------------------------+\n",
|
"+-----------------------------------------------------------------------------+\n",
|
||||||
@ -87,10 +87,7 @@
|
|||||||
"name": "stdout",
|
"name": "stdout",
|
||||||
"output_type": "stream",
|
"output_type": "stream",
|
||||||
"text": [
|
"text": [
|
||||||
"WARNING:tensorflow:From <ipython-input-3-d1bfbb527297>:3: is_gpu_available (from tensorflow.python.framework.test_util) is deprecated and will be removed in a future version.\n",
|
"[PhysicalDevice(name='/physical_device:XLA_GPU:0', device_type='XLA_GPU')]\n"
|
||||||
"Instructions for updating:\n",
|
|
||||||
"Use `tf.config.list_physical_devices('GPU')` instead.\n",
|
|
||||||
"True\n"
|
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -101,30 +98,20 @@
|
|||||||
" memory_limit: 268435456\n",
|
" memory_limit: 268435456\n",
|
||||||
" locality {\n",
|
" locality {\n",
|
||||||
" }\n",
|
" }\n",
|
||||||
" incarnation: 8034786465358909470,\n",
|
" incarnation: 12436949185972503812,\n",
|
||||||
" name: \"/device:XLA_CPU:0\"\n",
|
" name: \"/device:XLA_CPU:0\"\n",
|
||||||
" device_type: \"XLA_CPU\"\n",
|
" device_type: \"XLA_CPU\"\n",
|
||||||
" memory_limit: 17179869184\n",
|
" memory_limit: 17179869184\n",
|
||||||
" locality {\n",
|
" locality {\n",
|
||||||
" }\n",
|
" }\n",
|
||||||
" incarnation: 13772661904993777233\n",
|
" incarnation: 9674938692146126962\n",
|
||||||
" physical_device_desc: \"device: XLA_CPU device\",\n",
|
" physical_device_desc: \"device: XLA_CPU device\",\n",
|
||||||
" name: \"/device:GPU:0\"\n",
|
|
||||||
" device_type: \"GPU\"\n",
|
|
||||||
" memory_limit: 5480775680\n",
|
|
||||||
" locality {\n",
|
|
||||||
" bus_id: 1\n",
|
|
||||||
" links {\n",
|
|
||||||
" }\n",
|
|
||||||
" }\n",
|
|
||||||
" incarnation: 8336380964433791501\n",
|
|
||||||
" physical_device_desc: \"device: 0, name: GeForce RTX 2070 SUPER, pci bus id: 0000:01:00.0, compute capability: 7.5\",\n",
|
|
||||||
" name: \"/device:XLA_GPU:0\"\n",
|
" name: \"/device:XLA_GPU:0\"\n",
|
||||||
" device_type: \"XLA_GPU\"\n",
|
" device_type: \"XLA_GPU\"\n",
|
||||||
" memory_limit: 17179869184\n",
|
" memory_limit: 17179869184\n",
|
||||||
" locality {\n",
|
" locality {\n",
|
||||||
" }\n",
|
" }\n",
|
||||||
" incarnation: 4817022749254415174\n",
|
" incarnation: 7870544216044264725\n",
|
||||||
" physical_device_desc: \"device: XLA_GPU device\"]"
|
" physical_device_desc: \"device: XLA_GPU device\"]"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
@ -136,7 +123,7 @@
|
|||||||
"source": [
|
"source": [
|
||||||
"import tensorflow as tf\n",
|
"import tensorflow as tf\n",
|
||||||
"from tensorflow.python.client import device_lib\n",
|
"from tensorflow.python.client import device_lib\n",
|
||||||
"print(tf.test.is_gpu_available(cuda_only=True))\n",
|
"print(tf.config.list_physical_devices('XLA_GPU'))\n",
|
||||||
"device_lib.list_local_devices()"
|
"device_lib.list_local_devices()"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
@ -148,11 +135,11 @@
|
|||||||
{
|
{
|
||||||
"data": {
|
"data": {
|
||||||
"text/plain": [
|
"text/plain": [
|
||||||
"tensor([[0.1091, 0.0178, 0.2500],\n",
|
"tensor([[0.0399, 0.1738, 0.2486],\n",
|
||||||
" [0.1409, 0.9612, 0.0325],\n",
|
" [0.7464, 0.1461, 0.8991],\n",
|
||||||
" [0.8944, 0.3869, 0.9657],\n",
|
" [0.7264, 0.9835, 0.8844],\n",
|
||||||
" [0.8131, 0.5454, 0.2587],\n",
|
" [0.4544, 0.8331, 0.8435],\n",
|
||||||
" [0.6570, 0.0147, 0.1361]])"
|
" [0.0109, 0.0689, 0.2997]])"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"execution_count": 4,
|
"execution_count": 4,
|
||||||
@ -202,7 +189,7 @@
|
|||||||
"name": "stdout",
|
"name": "stdout",
|
||||||
"output_type": "stream",
|
"output_type": "stream",
|
||||||
"text": [
|
"text": [
|
||||||
"248 ms ± 174 µs per loop (mean ± std. dev. of 7 runs, 1 loop each)\n"
|
"276 ms ± 9.97 ms per loop (mean ± std. dev. of 7 runs, 1 loop each)\n"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
@ -236,13 +223,13 @@
|
|||||||
"name": "stdout",
|
"name": "stdout",
|
||||||
"output_type": "stream",
|
"output_type": "stream",
|
||||||
"text": [
|
"text": [
|
||||||
"78.2 ms ± 250 µs per loop (mean ± std. dev. of 7 runs, 10 loops each)\n"
|
"82.1 ms ± 1.85 ms per loop (mean ± std. dev. of 7 runs, 10 loops each)\n"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"source": [
|
"source": [
|
||||||
"%%timeit\n",
|
"%%timeit\n",
|
||||||
"# Calculate the projection matrix of x\n",
|
"# Calculate the projection matrix of x on the CPU\n",
|
||||||
"H = x.mm( (x.t().mm(x)).inverse() ).mm(x.t())"
|
"H = x.mm( (x.t().mm(x)).inverse() ).mm(x.t())"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
@ -262,16 +249,16 @@
|
|||||||
"name": "stdout",
|
"name": "stdout",
|
||||||
"output_type": "stream",
|
"output_type": "stream",
|
||||||
"text": [
|
"text": [
|
||||||
"tensor([[0.0962, 0.3125, 0.7327, 0.5982, 0.4624],\n",
|
"tensor([[0.2854, 0.3384, 0.6473, 0.0433, 0.5640],\n",
|
||||||
" [0.4655, 0.4890, 0.9603, 0.4339, 0.0524],\n",
|
" [0.3960, 0.0449, 0.6597, 0.5347, 0.8402],\n",
|
||||||
" [0.9294, 0.9639, 0.6312, 0.1752, 0.7721],\n",
|
" [0.0048, 0.9231, 0.0311, 0.2545, 0.0409],\n",
|
||||||
" [0.5533, 0.3656, 0.9329, 0.8796, 0.9513],\n",
|
" [0.6506, 0.8651, 0.7558, 0.1086, 0.8135],\n",
|
||||||
" [0.4949, 0.0972, 0.2892, 0.7570, 0.2847]], device='cuda:0')\n",
|
" [0.1083, 0.0039, 0.6049, 0.3596, 0.1359]], device='cuda:0')\n",
|
||||||
"tensor([[0.0962, 0.3125, 0.7327, 0.5982, 0.4624],\n",
|
"tensor([[0.2854, 0.3384, 0.6473, 0.0433, 0.5640],\n",
|
||||||
" [0.4655, 0.4890, 0.9603, 0.4339, 0.0524],\n",
|
" [0.3960, 0.0449, 0.6597, 0.5347, 0.8402],\n",
|
||||||
" [0.9294, 0.9639, 0.6312, 0.1752, 0.7721],\n",
|
" [0.0048, 0.9231, 0.0311, 0.2545, 0.0409],\n",
|
||||||
" [0.5533, 0.3656, 0.9329, 0.8796, 0.9513],\n",
|
" [0.6506, 0.8651, 0.7558, 0.1086, 0.8135],\n",
|
||||||
" [0.4949, 0.0972, 0.2892, 0.7570, 0.2847]], dtype=torch.float64)\n"
|
" [0.1083, 0.0039, 0.6049, 0.3596, 0.1359]], dtype=torch.float64)\n"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
@ -295,12 +282,13 @@
|
|||||||
"name": "stdout",
|
"name": "stdout",
|
||||||
"output_type": "stream",
|
"output_type": "stream",
|
||||||
"text": [
|
"text": [
|
||||||
"11.4 ms ± 60.2 µs per loop (mean ± std. dev. of 7 runs, 1 loop each)\n"
|
"11.4 ms ± 28.8 µs per loop (mean ± std. dev. of 7 runs, 1 loop each)\n"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"source": [
|
"source": [
|
||||||
"%%timeit\n",
|
"%%timeit\n",
|
||||||
|
"# Calculate the projection matrix of x on the GPU\n",
|
||||||
"H = x.mm( (x.t().mm(x)).inverse() ).mm(x.t())"
|
"H = x.mm( (x.t().mm(x)).inverse() ).mm(x.t())"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
@ -341,11 +329,11 @@
|
|||||||
"name": "stdout",
|
"name": "stdout",
|
||||||
"output_type": "stream",
|
"output_type": "stream",
|
||||||
"text": [
|
"text": [
|
||||||
"tensor([[0.4303, 0.7364, 0.1235, 0.7786, 0.7036],\n",
|
"tensor([[0.1101, 0.7887, 0.0641, 0.1327, 0.1681],\n",
|
||||||
" [0.3256, 0.4515, 0.7994, 0.9814, 0.7705],\n",
|
" [0.7914, 0.7248, 0.7731, 0.2662, 0.4908],\n",
|
||||||
" [0.2292, 0.5194, 0.4354, 0.3964, 0.5804],\n",
|
" [0.2451, 0.3568, 0.4006, 0.2099, 0.5212],\n",
|
||||||
" [0.8855, 0.5156, 0.9321, 0.9555, 0.4150],\n",
|
" [0.6195, 0.5120, 0.5212, 0.7321, 0.2272],\n",
|
||||||
" [0.0640, 0.0665, 0.1170, 0.9547, 0.2668]], device='cuda:0')\n"
|
" [0.2374, 0.4540, 0.0868, 0.9393, 0.1561]], device='cuda:0')\n"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
@ -376,11 +364,11 @@
|
|||||||
"name": "stdout",
|
"name": "stdout",
|
||||||
"output_type": "stream",
|
"output_type": "stream",
|
||||||
"text": [
|
"text": [
|
||||||
"tensor([[1.0966e-03, 3.5866e-04, 4.0044e-04, 3.2466e-04, 2.3044e-04],\n",
|
"tensor([[ 6.4681e-04, -1.5392e-05, 3.3608e-04, 2.1025e-04, 8.0912e-05],\n",
|
||||||
" [3.5866e-04, 9.7424e-04, 2.8649e-04, 8.2904e-04, 2.0482e-04],\n",
|
" [-1.5392e-05, 5.0718e-04, -1.1769e-04, -2.3084e-05, -2.3264e-04],\n",
|
||||||
" [4.0044e-04, 2.8649e-04, 5.4179e-04, 1.2729e-04, 9.4659e-05],\n",
|
" [ 3.3608e-04, -1.1769e-04, 6.9678e-04, 2.2663e-04, -1.8900e-04],\n",
|
||||||
" [3.2466e-04, 8.2904e-04, 1.2729e-04, 1.3005e-03, 6.6951e-06],\n",
|
" [ 2.1025e-04, -2.3084e-05, 2.2663e-04, 6.0036e-04, 2.7787e-04],\n",
|
||||||
" [2.3044e-04, 2.0482e-04, 9.4659e-05, 6.6950e-06, 1.3420e-03]],\n",
|
" [ 8.0912e-05, -2.3264e-04, -1.8900e-04, 2.7787e-04, 1.4208e-03]],\n",
|
||||||
" device='cuda:0')\n"
|
" device='cuda:0')\n"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
@ -399,11 +387,11 @@
|
|||||||
"name": "stdout",
|
"name": "stdout",
|
||||||
"output_type": "stream",
|
"output_type": "stream",
|
||||||
"text": [
|
"text": [
|
||||||
"tensor([[1.0966e-03, 3.5866e-04, 4.0044e-04, 3.2466e-04, 2.3044e-04],\n",
|
"tensor([[ 6.4681e-04, -1.5392e-05, 3.3608e-04, 2.1025e-04, 8.0912e-05],\n",
|
||||||
" [3.5866e-04, 9.7424e-04, 2.8649e-04, 8.2904e-04, 2.0482e-04],\n",
|
" [-1.5392e-05, 5.0718e-04, -1.1769e-04, -2.3084e-05, -2.3264e-04],\n",
|
||||||
" [4.0044e-04, 2.8649e-04, 5.4179e-04, 1.2729e-04, 9.4659e-05],\n",
|
" [ 3.3608e-04, -1.1769e-04, 6.9678e-04, 2.2663e-04, -1.8900e-04],\n",
|
||||||
" [3.2466e-04, 8.2904e-04, 1.2729e-04, 1.3005e-03, 6.6951e-06],\n",
|
" [ 2.1025e-04, -2.3084e-05, 2.2663e-04, 6.0036e-04, 2.7787e-04],\n",
|
||||||
" [2.3044e-04, 2.0482e-04, 9.4659e-05, 6.6950e-06, 1.3420e-03]],\n",
|
" [ 8.0912e-05, -2.3264e-04, -1.8900e-04, 2.7787e-04, 1.4208e-03]],\n",
|
||||||
" dtype=torch.float64)\n"
|
" dtype=torch.float64)\n"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -4,10 +4,14 @@ cd $(cd -P -- "$(dirname -- "$0")" && pwd -P)
|
|||||||
# Set the path of the generated Dockerfile
|
# Set the path of the generated Dockerfile
|
||||||
export DOCKERFILE=".build/Dockerfile"
|
export DOCKERFILE=".build/Dockerfile"
|
||||||
export STACKS_DIR=".build/docker-stacks"
|
export STACKS_DIR=".build/docker-stacks"
|
||||||
export HEAD_COMMIT="c1c32938438151c7e2a22b5aa338caba2ec01da2"
|
# please test the build of the commit in https://github.com/jupyter/docker-stacks/commits/master in advance
|
||||||
|
export HEAD_COMMIT="04f7f60d34a674a2964d96a6cb97c57a7870a828"
|
||||||
|
|
||||||
while [[ "$#" -gt 0 ]]; do case $1 in
|
while [[ "$#" -gt 0 ]]; do case $1 in
|
||||||
-c|--commit) HEAD_COMMIT="$2"; shift;;
|
-c|--commit) HEAD_COMMIT="$2"; shift;;
|
||||||
|
--no-datascience-notebook) no_datascience_notebook=1;;
|
||||||
|
--no-useful-packages) no_useful_packages=1;;
|
||||||
|
-s|--slim) no_datascience_notebook=1 && no_useful_packages=1;;
|
||||||
*) echo "Unknown parameter passed: $1" &&
|
*) echo "Unknown parameter passed: $1" &&
|
||||||
echo "Usage: $0 -c [sha-commit] # set the head commit of the docker-stacks submodule
|
echo "Usage: $0 -c [sha-commit] # set the head commit of the docker-stacks submodule
|
||||||
(https://github.com/jupyter/docker-stacks/commits/master). default: $HEAD_COMMIT."; exit 1;;
|
(https://github.com/jupyter/docker-stacks/commits/master). default: $HEAD_COMMIT."; exit 1;;
|
||||||
@ -23,11 +27,12 @@ if [[ "$HEAD_COMMIT" == "latest" ]]; then
|
|||||||
cd $STACKS_DIR && git pull && cd -
|
cd $STACKS_DIR && git pull && cd -
|
||||||
else
|
else
|
||||||
export GOT_HEAD="false"
|
export GOT_HEAD="false"
|
||||||
cd $STACKS_DIR && git reset --hard "$HEAD_COMMIT" > /dev/null 2>&1 && cd - && export GOT_HEAD="true"
|
cd $STACKS_DIR && git pull && git reset --hard "$HEAD_COMMIT" > /dev/null 2>&1 && cd - && export GOT_HEAD="true"
|
||||||
echo "$HEAD"
|
echo "$HEAD"
|
||||||
if [[ "$GOT_HEAD" == "false" ]]; then
|
if [[ "$GOT_HEAD" == "false" ]]; then
|
||||||
echo "Given sha-commit is invalid."
|
echo "Error: The given sha-commit is invalid."
|
||||||
echo "Usage: $0 -c [sha-commit] # set the head commit of the docker-stacks submodule (https://github.com/jupyter/docker-stacks/commits/master)."
|
echo "Usage: $0 -c [sha-commit] # set the head commit of the docker-stacks submodule (https://github.com/jupyter/docker-stacks/commits/master)."
|
||||||
|
echo "Exiting"
|
||||||
exit 2
|
exit 2
|
||||||
else
|
else
|
||||||
echo "Set head to given commit."
|
echo "Set head to given commit."
|
||||||
@ -66,13 +71,17 @@ echo "
|
|||||||
" >> $DOCKERFILE
|
" >> $DOCKERFILE
|
||||||
cat $STACKS_DIR/scipy-notebook/Dockerfile | grep -v BASE_CONTAINER >> $DOCKERFILE
|
cat $STACKS_DIR/scipy-notebook/Dockerfile | grep -v BASE_CONTAINER >> $DOCKERFILE
|
||||||
|
|
||||||
echo "
|
# install Julia and R if not excluded or spare mode is used
|
||||||
############################################################################
|
if [[ "$no_datascience_notebook" != 1 ]]; then
|
||||||
################ Dependency: jupyter/datascience-notebook ##################
|
echo "
|
||||||
############################################################################
|
############################################################################
|
||||||
" >> $DOCKERFILE
|
################ Dependency: jupyter/datascience-notebook ##################
|
||||||
cat $STACKS_DIR/datascience-notebook/Dockerfile | grep -v BASE_CONTAINER >> $DOCKERFILE
|
############################################################################
|
||||||
|
" >> $DOCKERFILE
|
||||||
|
cat $STACKS_DIR/datascience-notebook/Dockerfile | grep -v BASE_CONTAINER >> $DOCKERFILE
|
||||||
|
else
|
||||||
|
echo "Set 'no-datascience-notebook', not installing the datascience-notebook with Julia and R."
|
||||||
|
fi
|
||||||
|
|
||||||
# Note that the following step also installs the cudatoolkit, which is
|
# Note that the following step also installs the cudatoolkit, which is
|
||||||
# essential to access the GPU.
|
# essential to access the GPU.
|
||||||
@ -83,13 +92,17 @@ echo "
|
|||||||
" >> $DOCKERFILE
|
" >> $DOCKERFILE
|
||||||
cat src/Dockerfile.gpulibs >> $DOCKERFILE
|
cat src/Dockerfile.gpulibs >> $DOCKERFILE
|
||||||
|
|
||||||
|
# install useful packages if not excluded or spare mode is used
|
||||||
echo "
|
if [[ "$no_useful_packages" != 1 ]]; then
|
||||||
############################################################################
|
echo "
|
||||||
############################ Useful packages ###############################
|
############################################################################
|
||||||
############################################################################
|
############################ Useful packages ###############################
|
||||||
" >> $DOCKERFILE
|
############################################################################
|
||||||
cat src/Dockerfile.usefulpackages >> $DOCKERFILE
|
" >> $DOCKERFILE
|
||||||
|
cat src/Dockerfile.usefulpackages >> $DOCKERFILE
|
||||||
|
else
|
||||||
|
echo "Set 'no-useful-packages', not installing stuff within src/Dockerfile.usefulpackages."
|
||||||
|
fi
|
||||||
|
|
||||||
# Copy the demo notebooks and change permissions
|
# Copy the demo notebooks and change permissions
|
||||||
cp -r extra/Getting_Started data
|
cp -r extra/Getting_Started data
|
||||||
|
@ -1,11 +1,15 @@
|
|||||||
LABEL maintainer="Christoph Schranz <christoph.schranz@salzburgresearch.at>"
|
LABEL maintainer="Christoph Schranz <christoph.schranz@salzburgresearch.at>"
|
||||||
|
|
||||||
# Install Tensorflow, check compatibility here: https://www.tensorflow.org/install/gpu
|
# Install Tensorflow, check compatibility here: https://www.tensorflow.org/install/gpu
|
||||||
RUN conda install --quiet --yes \
|
# installation via conda leads to errors in version 4.8.2
|
||||||
'tensorflow-gpu=2.1*' \
|
#RUN conda install --quiet --yes \
|
||||||
'keras-gpu' && \
|
# 'tensorflow-gpu=2.1*' \
|
||||||
fix-permissions $CONDA_DIR && \
|
# 'keras-gpu' && \
|
||||||
fix-permissions /home/$NB_USER
|
# fix-permissions $CONDA_DIR && \
|
||||||
|
# fix-permissions /home/$NB_USER
|
||||||
|
RUN pip install --upgrade pip && \
|
||||||
|
pip install --no-cache-dir "tensorflow-gpu>=2.1.*" && \
|
||||||
|
pip install --no-cache-dir keras
|
||||||
|
|
||||||
# Install PyTorch with dependencies
|
# Install PyTorch with dependencies
|
||||||
RUN conda install --quiet --yes \
|
RUN conda install --quiet --yes \
|
||||||
|
@ -2,4 +2,4 @@
|
|||||||
# The version of cudatoolkit must match those of the base image, see Dockerfile.pytorch
|
# The version of cudatoolkit must match those of the base image, see Dockerfile.pytorch
|
||||||
FROM nvidia/cuda:10.1-base-ubuntu18.04
|
FROM nvidia/cuda:10.1-base-ubuntu18.04
|
||||||
LABEL maintainer="Christoph Schranz <christoph.schranz@salzburgresearch.at>"
|
LABEL maintainer="Christoph Schranz <christoph.schranz@salzburgresearch.at>"
|
||||||
# The maintainers of subsequent sections may vary
|
# This is a concatenated Dockerfile, the maintainers of subsequent sections may vary.
|
||||||
|
Loading…
Reference in New Issue
Block a user