This is a Dockerfile to build a container image for python, with the ability to push and pull source code to and from git (including an optional automatic git pull whenever the container is restarted).
The source files for this project can be found here: https://github.com/TheBoroer/docker-python
If you have any improvements please submit a pull request.
The Docker hub build can be found here: https://hub.docker.com/u/boro/python/
Tag | Python | Alpine |
---|---|---|
3.12 | 3.12.x | 3.17 |
3.11 | 3.11.x | 3.17 |
3.10 | 3.10.x | 3.17 |
3.9 | 3.9.x | 3.17 |
3.9.16 | 3.9.16 | 3.6 |
3.8.6 | 3.8.6 | 3.12 |
3.6.4 | 3.6.4 | 3.6 |
2.7.14 | 2.7.14 | 3.6 |
.x
means it'll use the latest version available at the time this image was built.
docker pull boro/python
To simply run the container:
sudo docker run -d boro/python
To install modules/components for your python application to run simply include a requirements.txt
file in the root of your application. The container will then install the components on start.
The following flags are a list of all the currently supported options that can be changed by passing in the variables to docker with the -e flag.
- GIT_REPO : URL to the repository containing your source code. If you are using a personal token, this is the https URL without https://, e.g github.com/project/ for ssh prepend with git@ e.g git@github.com:project.git
- GIT_BRANCH : Select a specific branch (optional)
- GIT_EMAIL : Set your email for code pushing (required for git to work)
- GIT_NAME : Set your name for code pushing (required for git to work)
- GIT_PERSONAL_TOKEN : Personal access token for your git account (required for HTTPS git access)
- GIT_USERNAME : Git username for use with personal tokens. (required for HTTPS git access)
- GIT_REPULL : Set to 1 to perform a git pull every time the container restarts
- WORKDIR : Change the default webroot directory from
/app
to your own setting - RUN_SCRIPTS : Set to 1 to execute bash scripts in the
$WORKDIR/scripts
folder - PYTHON_CMD : set to the command you want to follow the python command. E.g. if set to "--version" it would run python --version in the container and print the python version.
- RUN_CMD : set to the shell/bash command you want to run (works only if no PYTHON_CMD is specified).
One of the nice features of this container is its ability to pull code from a git repository with a couple of environmental variables passed at run time.
REQUIRED: To create a personal access token on Github follow this guide.
You can pass the container your personal access token from your git account using the GIT_PERSONAL_TOKEN flag. This token must be setup with the correct permissions in git in order to push and pull code.
Since the access token acts as a password with limited access, the git push/pull uses HTTPS to authenticate. You will need to specify your GIT_USERNAME and GIT_PERSONAL_TOKEN variables to push and pull. You'll need to also have the GIT_EMAIL, GIT_NAME and GIT_REPO common variables defined.
docker run -d -e 'GIT_EMAIL=email_address' -e 'GIT_NAME=full_name' -e 'GIT_USERNAME=git_username' -e 'GIT_REPO=github.com/project' -e 'GIT_PERSONAL_TOKEN=<long_token_string_here>' boro/python:latest
To pull a repository and specify a branch add the GIT_BRANCH environment variable:
docker run -d -e 'GIT_EMAIL=email_address' -e 'GIT_NAME=full_name' -e 'GIT_USERNAME=git_username' -e 'GIT_REPO=github.com/project' -e 'GIT_PERSONAL_TOKEN=<long_token_string_here>' -e 'GIT_BRANCH=stage' boro/python:latest
There is often an occasion where you need to run a bash script on code to do a transformation once code lands in the container. For this reason there's scripting support. By including a scripts folder in your git repository and passing the RUN_SCRIPTS=1 flag to your command line the container will execute your bash scripts after code is pulled via git.
Specify the GIT_EMAIL
and GIT_NAME
variables for this to work. They are used to set up git correctly and allow the following commands to work.
To push code changes made within the container back to git run:
sudo docker exec -t -i <CONTAINER_NAME> /usr/bin/push
In order to refresh the code in a container and pull newer code from git run:
sudo docker exec -t -i <CONTAINER_NAME> /usr/bin/pull
To set the variables pass them in as environment variables on the docker command line.
Example:
sudo docker run -d -e 'YOUR_VAR=VALUE' boro/python
All logs should now print out in stdout/stderr and are available via the docker logs command:
docker logs <CONTAINER_NAME>
You can set your workdir in the container to anything you want using the WORKDIR
variable e.g -e "WORKDIR=/app/some/other/director". By default code is checked out into /app/ so if your git repository does not have code in the root you'll need to use this variable.