- Docker Images
- Environment Variables
- Build arguments
- Changelog
- Users and permissions
- Crond
- SSHD
- Adding SSH key
- Complete Python stack
- Orchestration Actions
❗For better reliability we release images with stability tags (wodby/python:3.9-X.X.X
) which correspond to git tags. We strongly recommend using images only with stability tags.
About images:
- All images based on Alpine Linux
- Base image: python
- GitHub actions builds
- Docker Hub
Supported tags and respective Dockerfile
links:
3.9
,3
,latest
(Dockerfile)3.8
(Dockerfile)3.7
(Dockerfile)3.6
(Dockerfile)3.9-dev
,3-dev
(Dockerfile)3.8-dev
(Dockerfile)3.7-dev
(Dockerfile)3.6-dev
(Dockerfile)3.9-dev-macos
,3-dev-macos
(Dockerfile)3.8-dev-macos
(Dockerfile)3.7-dev-macos
(Dockerfile)3.6-dev-macos
(Dockerfile)
Images with -dev
tag have sudo
allowed for all commands for wodby
user.
Same as -dev
but the default user/group wodby
has uid/gid 501
/20
to match the macOS default user/group ids.
All images built for linux/amd64
, -dev-macos
images additionally built for linux/arm64
Variable | Default value |
---|---|
GIT_USER_EMAIL |
wodby@example.com |
GIT_USER_NAME |
wodby |
GUNICORN_APP |
myapp.wsgi:application |
GUNICORN_BACKLOG |
2048 |
GUNICORN_KEEPALIVE |
2 |
GUNICORN_LOGLEVEL |
info |
GUNICORN_PROC_NAME |
Gunicorn |
GUNICORN_PYTHONPATH |
|
GUNICORN_SPEW |
False |
GUNICORN_TIMEOUT |
30 |
GUNICORN_WORKER_CLASS |
sync |
GUNICORN_WORKER_CONNECTIONS |
1000 |
GUNICORN_WORKERS |
4 |
SSH_DISABLE_STRICT_KEY_CHECKING |
|
SSH_PRIVATE_KEY |
|
SSHD_GATEWAY_PORTS |
no |
SSHD_HOST_KEYS_DIR |
/etc/ssh |
SSHD_LOG_LEVEL |
INFO |
SSHD_PASSWORD_AUTHENTICATION |
no |
SSHD_PERMIT_USER_ENV |
no |
SSHD_USE_DNS |
yes |
Argument | Default value |
---|---|
PYTHON_DEV |
|
PYTHON_DEBUG |
|
WODBY_GROUP_ID |
1000 |
WODBY_USER_ID |
1000 |
Change WODBY_USER_ID
and WODBY_GROUP_ID
mainly for local dev version of images, if it matches with existing system user/group ids the latter will be deleted.
Changes per stability tag reflected in git tags description under releases.
You can run Crond with this image changing the command to sudo -E crond -f -d 0
and mounting a crontab file to ./crontab:/etc/crontabs/www-data
. Example crontab file contents:
# min hour day month weekday command
*/1 * * * * echo "test" > /mnt/files/cron
You can run SSHD with this image by changing the command to sudo /usr/sbin/sshd -De
and mounting authorized public keys to /home/wodby/.ssh/authorized_keys
You can add a private SSH key to the container by mounting it to /home/wodby/.ssh/id_rsa
Default container user is wodby:wodby
(UID/GID 1000
). Gunicorn runs from www-data:www-data
user (UID/GID 82
) by default. User wodby
is a part of www-data
group.
Codebase volume $APP_ROOT
(/usr/src/app
) owned by wodby:wodby
. Files volume $FILES_DIR
(/mnt/files
) owned by www-data:www-data
with 775
mode.
-
files_chmod
– in case you need write access forwodby
user to a file/dir generated bywww-data
on this volume runsudo files_chmod [FILEPATH]
script (FILEPATH must be under/mnt/files
), it will recursively change the mode toug=rwX,o=rX
-
files_chown
– in case you manually uploaded files underwodby
user to files volume and want to change the ownership of those files towww-data
runsudo files_chown [FILEPATH]
script (FILEPATH must be under/mnt/files
), it will recursively change ownership towww-data:www-data
See https://github.com/wodby/docker4python
Usage:
make COMMAND [params ...]
commands:
migrate
check-ready [host max_try wait_seconds delay_seconds]
files-import source
files-link public_dir