-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathDockerfile
183 lines (145 loc) · 5.74 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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
################################################################################
# IMAGE: Base build image
#
FROM python:3.12-slim AS base
ENV PYTHONUNBUFFERED=1 \
PIP_DISABLE_PIP_VERSION_CHECK=on \
PIP_DEFAULT_TIMEOUT=100 \
BASE="/opt/harp" \
POETRY_VERSION=1.7.1 \
POETRY_HOME="/opt/poetry" \
POETRY_NO_INTERACTION=1 \
POETRY_VIRTUALENVS_CREATE=false \
VIRTUAL_ENV="/opt/venv" \
NODE_MAJOR=20
# system dependencies layer
USER root
WORKDIR /root
RUN --mount=type=cache,target=/root/.cache,sharing=locked \
--mount=type=cache,target=/var/cache/apt,sharing=locked \
apt-get update \
&& apt-get install -y make curl ca-certificates \
&& rm -rf /var/lib/apt/lists/* \
&& useradd -m harp -g www-data -d ${BASE} -u 500 \
&& echo 'alias l="ls -lsah --color"' > /opt/harp/.profile \
&& echo 'export PATH="${POETRY_HOME}/bin:${VIRTUAL_ENV}/bin:$PATH"' >> /opt/harp/.profile
# global python dependencies layer
RUN --mount=type=cache,target=/root/.cache,sharing=locked \
pip install 'poetry==1.7.1' \
&& python3 -m venv ${VIRTUAL_ENV}
# fix permissions
RUN chown harp:www-data -R /opt/harp /opt/venv
USER harp
WORKDIR /opt/harp
################################################################################
# IMAGE: Backend builder image (install prod deps in a virtualenv ready to be copied to runtime)
#
FROM base AS backend
# Step: Add system build dependencies
USER root
WORKDIR /root
RUN --mount=type=cache,target=/root/.cache,sharing=locked \
--mount=type=cache,target=/var/cache/apt,sharing=locked \
apt-get update \
&& apt-get install -y build-essential \
&& rm -rf /var/lib/apt/lists/*
# Step: Add sources and install dependencies (prod)
USER harp
WORKDIR /opt/harp
ADD --chown=harp:www-data . src
# ... install
RUN --mount=type=cache,target=/opt/harp/.cache,uid=500,sharing=locked \
(cd src; poetry config --list; poetry debug info; poetry install --only main)
# Step: Fix cache directory permissions: this wont delete the content, just the directory that may have strange \
# permissions caused by the cache mounts.
RUN rm -rf .cache
################################################################################
# IMAGE: Development image (ability to use from sources, run tests, run dev servers ...)
#
FROM base AS development
# Step: Add system build dependencies
USER root
WORKDIR /root
RUN --mount=type=cache,target=/root/.cache,sharing=locked \
--mount=type=cache,target=/var/cache/apt,sharing=locked \
curl -fsSL https://deb.nodesource.com/setup_20.x | bash - \
&& curl -sSL https://get.docker.com/ | sh \
&& apt-get install -y build-essential \
&& apt-get install -y nodejs \
&& apt-get install -y vim net-tools iputils-ping netcat-openbsd bind9-host jq \
&& rm -rf /var/lib/apt/lists/* \
&& npm install -g pnpm
# Step: Add sources, install dependencies (dev) and build assets
USER harp
WORKDIR /opt/harp
ADD --chown=harp:www-data . src
# ... install and build
RUN --mount=type=cache,target=/opt/harp/.cache,uid=500,sharing=locked \
(cd src; poetry config --list; poetry debug info; poetry install) \
&& (cd src/harp_apps/dashboard/frontend; pnpm install);
# Development image scripts are on the shelf
RUN mv src/bin/development ./bin
# No need for cache directory
RUN rm -rf .cache
################################################################################
# IMAGE: Frontend builder image (ability to compile frontend app into production version)
#
FROM base AS frontend
# Step: Add system build dependencies
USER root
WORKDIR /root
RUN --mount=type=cache,target=/root/.cache,sharing=locked \
--mount=type=cache,target=/var/cache/apt,sharing=locked \
curl -fsSL https://deb.nodesource.com/setup_20.x | bash - \
&& apt-get install -y build-essential \
&& apt-get install -y nodejs \
&& rm -rf /var/lib/apt/lists/* \
&& npm install -g pnpm
USER harp
WORKDIR /opt/harp
ADD --chown=harp:www-data ./harp_apps/dashboard/frontend frontend/dashboard
RUN (cd frontend/dashboard; pnpm install; pnpm build)
################################################################################
# IMAGE: Lightest possible image, with only production related abilities
#
FROM python:3.12-slim AS runtime
ENV PYTHONUNBUFFERED=1 \
PIP_DISABLE_PIP_VERSION_CHECK=on \
PIP_DEFAULT_TIMEOUT=100 \
BASE="/opt/harp" \
POETRY_VERSION=1.7.1 \
POETRY_HOME="/opt/poetry" \
POETRY_NO_INTERACTION=1 \
POETRY_VIRTUALENVS_CREATE=false \
VIRTUAL_ENV="/opt/venv" \
NODE_MAJOR=20
# system dependencies layer
USER root
WORKDIR /root
RUN --mount=type=cache,target=/root/.cache,sharing=locked \
--mount=type=cache,target=/var/cache/apt,sharing=locked \
apt-get update \
&& apt-get install -y make curl ca-certificates httpie \
&& rm -rf /var/lib/apt/lists/* \
&& useradd -m harp -g www-data -d ${BASE} -u 500 \
&& mkdir -p /var/lib/harp/data \
&& echo 'alias l="ls -lsah --color"' > /opt/harp/.profile \
&& echo 'export PATH="${POETRY_HOME}/bin:${VIRTUAL_ENV}/bin:$PATH"' >> /opt/harp/.profile
ENV TINI_VERSION="v0.19.0"
ADD https://github.com/krallin/tini/releases/download/${TINI_VERSION}/tini /tini
RUN chmod +x /tini
RUN chown harp:www-data -R /opt/harp /var/lib/harp/data
RUN echo "{}" > /etc/harp.yaml
USER harp
WORKDIR ${BASE}
COPY --from=backend ${VIRTUAL_ENV} ${VIRTUAL_ENV}
COPY --from=frontend ${BASE}/frontend/web ${BASE}/src/harp_apps/dashboard/web
COPY --from=backend --chown=harp:www-data ${BASE}/src ${BASE}/src
RUN ln -s ${BASE}/src/harp_apps/dashboard/web public
RUN ln -s /var/lib/harp/data \
&& ln -s /etc/harp.yaml \
&& mv src/bin/runtime ./bin
ENV DEFAULT__HARP__STORAGE__URL="sqlite+aiosqlite:///data/harp.db"
EXPOSE 4080
ENTRYPOINT [ "/tini", "--", "/opt/venv/bin/python3", "-m", "harp" ]
CMD [ "server" ]