-
Notifications
You must be signed in to change notification settings - Fork 22
Expand file tree
/
Copy pathDockerfile
More file actions
52 lines (40 loc) · 1.55 KB
/
Dockerfile
File metadata and controls
52 lines (40 loc) · 1.55 KB
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
# Use a Python image with uv pre-installed
FROM ghcr.io/astral-sh/uv:python3.13-bookworm-slim
# Set environment variables for uv optimization
ENV UV_COMPILE_BYTECODE=1
ENV UV_LINK_MODE=copy
ENV PYTHONUNBUFFERED=1
ENV PYTHONDONTWRITEBYTECODE=1
ENV MALLA_HOST=0.0.0.0
ENV MALLA_PORT=5008
# Install the project into `/app`
WORKDIR /app
RUN apt update && apt install -y git
# Copy dependency files and metadata files (required for package build)
# Install the project's dependencies using the lockfile and settings
RUN --mount=type=cache,target=/root/.cache/uv \
--mount=type=bind,source=uv.lock,target=uv.lock \
--mount=type=bind,source=pyproject.toml,target=pyproject.toml \
--mount=type=bind,source=LICENSE,target=LICENSE \
--mount=type=bind,source=README.md,target=README.md \
uv sync --locked --no-install-project --no-dev
# Then, add the rest of the project source code and install it
# Installing separately from its dependencies allows optimal layer caching
COPY . /app
RUN --mount=type=cache,target=/root/.cache/uv \
uv sync --locked --no-dev
# Create app user
RUN groupadd --gid 1000 app && \
useradd --uid 1000 --gid 1000 --create-home --shell /bin/bash app
# Create data directory for database and set permissions
RUN mkdir -p /app/data && chown -R app:app /app
# Switch to non-root user
USER app
# Place executables in the environment at the front of the path
ENV PATH="/app/.venv/bin:$PATH"
# Reset the entrypoint, don't invoke `uv`
ENTRYPOINT []
# Expose port
EXPOSE 5008
# Default command runs the web UI
CMD ["/app/.venv/bin/malla-web"]