This repository has been archived by the owner on Jul 20, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Dockerfile
45 lines (37 loc) · 1.69 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
FROM python:3.10-slim
# Install packages needed to run your application (not build deps):
# mime-support -- for mime types when serving static files
# git, because pip needs this to pull an image
# libmagic-dev, because our project uses magic to detect file types
# texlive-* -- for pdf support
# We need to recreate the /usr/share/man/man{1..8} directories first because
# they were clobbered by a parent image.
RUN set -ex \
&& RUN_DEPS=" \
mime-support \
python3-pip python3-venv \
git \
libmagic-dev \
texlive-base texlive-lang-german texlive-fonts-recommended \
" \
&& seq 1 8 | xargs -I{} mkdir -p /usr/share/man/man{} \
&& apt-get update && apt-get install -y --no-install-recommends $RUN_DEPS \
&& rm -rf /var/lib/apt/lists/*
ADD requirements_staging.txt /requirements_staging.txt
RUN pip install --no-cache-dir -r /requirements_staging.txt
ADD requirements.txt /requirements.txt
RUN pip install --no-cache-dir -r /requirements.txt
# Copy your application code to the container (make sure you create a .dockerignore file if any large files or directories should be excluded)
RUN mkdir /code/
WORKDIR /code/
ADD . /code/
ENV DJANGO_SETTINGS_MODULE=toptool.settings.staging_settings
ENV DJANGO_SECRET_KEY=not-needed-in-docker
RUN python manage.py collectstatic --noinput --force-color \
&& rm -f *.sqlite3 \
&& python manage.py makemigrations --noinput \
&& python manage.py migrate --noinput|grep -v "... OK" \
&& echo "import toptool.fixtures as fixture;fixture.showroom_fixture_state_no_confirmation()"|python manage.py shell
ENV DJANGO_SECRET_KEY=
EXPOSE 8000
CMD ["gunicorn", "--bind", ":8000", "--workers", "1", "toptool.staging_wsgi:application"]