Docker Installation for Python
#
Method 1: docker pull python:3.5
Search for the Python image on Docker Hub:
You can view other versions of Python by sorting, with the default being the latest version python:latest.
Additionally, we can use the docker search python
command to see available versions:
tutorialpro@tutorialpro:~/python$ docker search python
NAME DESCRIPTION STARS OFFICIAL AUTOMATED
python Python is an interpreted,... 982 [OK]
kaggle/python Docker image for Python... 33 [OK]
azukiapp/python Docker image to run Python ... 3 [OK]
vimagick/python mini python 2 [OK]
tsuru/python Image for the Python ... 2 [OK]
pandada8/alpine-python An alpine based python image 1 [OK]
1science/python Python Docker images based on ... 1 [OK]
lucidfrontier45/python-uwsgi Python with uWSGI 1 [OK]
orbweb/python Python image 1 [OK]
pathwar/python Python template for Pathwar levels 1 [OK]
rounds/10m-python Python, setuptools and pip. 0 [OK]
ruimashita/python ubuntu 14.04 python 0 [OK]
tnanba/python Python on CentOS-7 image. 0 [OK]
Here, we pull the official image with the tag 3.5:
tutorialpro@tutorialpro:~/python$ docker pull python:3.5
After the download completes, we can find the image with the REPOSITORY as python
and the tag 3.5 in our local image list:
tutorialpro@tutorialpro:~/python$ docker images python:3.5
REPOSITORY TAG IMAGE ID CREATED SIZE
python 3.5 045767ddf24a 9 days ago 684.1 MB
Method 2: Build via Dockerfile
Create Dockerfile
First, create a directory python
to store the related files:
tutorialpro@tutorialpro:~$ mkdir -p ~/python ~/python/myapp
The myapp
directory will be mapped as the application directory for the Python container configuration.
Navigate to the created python
directory and create a Dockerfile:
FROM buildpack-deps:jessie
# remove several traces of debian python
RUN apt-get purge -y python.*
# http://bugs.python.org/issue19846
# > At the moment, setting "LANG=C" on a Linux system *fundamentally breaks Python 3*, and that's not OK.
ENV LANG C.UTF-8
# gpg: key F73C700D: public key "Larry Hastings <larry@hastings.org>" imported
ENV GPG_KEY 97FC712E4C024BBEA48A61ED3A5CA953F73C700D
ENV PYTHON_VERSION 3.5.1
# if this is called "PIP_VERSION", pip explodes with "ValueError: invalid truth value '<VERSION>'"
ENV PYTHON_PIP_VERSION 8.1.2
RUN set -ex \
&& curl -fSL "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz" -o python.tar.xz \
&& curl -fSL "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz.asc" -o python.tar.xz.asc \
&& export GNUPGHOME="$(mktemp -d)" \
&& gpg --keyserver ha.pool.sks-keyservers.net --recv-keys "$GPG_KEY" \
&& gpg --batch --verify python.tar.xz.asc python.tar.xz \
&& rm -r "$GNUPGHOME" python.tar.xz.asc \
&& mkdir -p /usr/src/python \
&& tar -xJC /usr/src/python --strip-components=1 -f python.tar.xz \
&& rm python.tar.xz \
\
&& cd /usr/src/python \
&& ./configure --enable-shared --enable-unicode=ucs4 \
&& make -j$(nproc) \
&& make install \
&& ldconfig \
&& pip3 install --no-cache-dir --upgrade --ignore-installed pip==$PYTHON_PIP_VERSION \
&& find /usr/local -depth \
\( \
\( -type d -a -name test -o -name tests \) \
-o \
\( -type f -a -name '*.pyc' -o -name '*.pyo' \) \
\) -exec rm -rf '{}' + \
&& rm -rf /usr/src/python ~/.cache
# make some useful symlinks that are expected to exist
RUN cd /usr/local/bin \
&& ln -s easy_install-3.5 easy_install \
&& ln -s idle3 idle \
&& ln -s pydoc3 pydoc \
&& ln -s python3 python \
&& ln -s python-config python-config
CMD ["python3"]
Create an image from the Dockerfile, replacing it with your own name:
tutorialpro@tutorialpro:~/python$ docker build -t python:3.5 .
After creation, we can find the newly created image in our local image list:
tutorialpro@tutorialpro:~/python$ docker images python:3.5
REPOSITORY TAG IMAGE ID CREATED SIZE
python 3.5 045767ddf24a 9 days ago 684.1 MB
Using the Python Image
Create a helloworld.py
file in the ~/python/myapp
directory with the following code:
#!/usr/bin/python
print("Hello, World!");
Run the Container
tutorialpro@tutorialpro:~/python$ docker run -v $PWD/myapp:/usr/src/myapp -w /usr/src/myapp python:3.5 python helloworld.py
Command explanation:
-v $PWD/myapp:/usr/src/myapp: Mounts the myapp
directory from the host's current directory to /usr/src/myapp
in the container.
-w /usr/src/myapp: Specifies the container's /usr/src/myapp directory as the working directory.
python helloworld.py: Uses the container's python command to execute the helloworld.py file in the working directory.
Output:
Hello, World!