Compare commits

...

4 Commits

Author SHA1 Message Date
f79cb6e91d fix: Remove more copies from dockerfile
All checks were successful
Build Docker / BuildImage (push) Successful in 1m2s
2026-02-18 12:06:28 +11:00
c72c045f23 fix: Remove broken dockerfile copies
Some checks failed
Build Docker / BuildImage (push) Failing after 31s
2026-02-18 12:02:21 +11:00
6e6eac6285 feat: Rename leader table header
Some checks failed
Build Docker / BuildImage (push) Failing after 32s
2026-02-18 12:00:44 +11:00
cd796bbe92 fix: Update Dockerfile
Some checks failed
Build Docker / BuildImage (push) Failing after 1m45s
2026-02-18 11:58:17 +11:00
3 changed files with 53 additions and 23 deletions

View File

@@ -1,17 +1,51 @@
FROM --platform=$BUILDPLATFORM python:3.10-alpine AS builder # syntax=docker/dockerfile:1
### Build stage ###
FROM python:3.13-alpine AS build
# Install build dependencies for Pillow and other native wheels
RUN apk add --no-cache \
build-base \
jpeg-dev zlib-dev freetype-dev
# Copy uv (fast Python package manager)
COPY --from=ghcr.io/astral-sh/uv:0.8.21 /uv /uvx /bin/
WORKDIR /app WORKDIR /app
COPY pyproject.toml uv.lock ./
COPY requirements.txt /app # Install dependencies into a virtual environment
RUN --mount=type=cache,target=/root/.cache/pip \ RUN --mount=type=cache,target=/root/.cache/uv \
python3 -m pip install -r requirements.txt uv sync --locked
COPY . /app # Copy only app source files
COPY main.py server.py ./
COPY templates templates
# Optionally mount /data to store the data # Clean up caches and pycache
# VOLUME /data RUN rm -rf /root/.cache/uv
RUN find . -type d -name "__pycache__" -exec rm -rf {} +
ENTRYPOINT ["python3"]
CMD ["main.py"]
FROM builder as dev-envs ### Runtime stage ###
FROM python:3.13-alpine AS runtime
ENV PATH="/app/.venv/bin:$PATH"
# Create non-root user
RUN addgroup -g 1001 appgroup && \
adduser -D -u 1001 -G appgroup -h /app appuser
WORKDIR /app
RUN apk add --no-cache curl
# Copy only whats needed for runtime
COPY --from=build --chown=appuser:appgroup /app/.venv /app/.venv
COPY --from=build --chown=appuser:appgroup /app/templates /app/templates
COPY --from=build --chown=appuser:appgroup /app/main.py /app/
COPY --from=build --chown=appuser:appgroup /app/server.py /app/
USER appuser
EXPOSE 5000
ENTRYPOINT ["python3", "main.py"]

18
main.py
View File

@@ -1,5 +1,3 @@
from flask import Flask
from server import app
import server import server
from gunicorn.app.base import BaseApplication from gunicorn.app.base import BaseApplication
import os import os
@@ -21,22 +19,20 @@ class GunicornApp(BaseApplication):
return self.application return self.application
if __name__ == "__main__":
if __name__ == '__main__':
dotenv.load_dotenv() dotenv.load_dotenv()
workers = os.getenv('WORKERS', 1) workers = os.getenv("WORKERS", 1)
threads = os.getenv('THREADS', 2) threads = os.getenv("THREADS", 2)
workers = int(workers) workers = int(workers)
threads = int(threads) threads = int(threads)
options = { options = {
'bind': '0.0.0.0:5000', "bind": "0.0.0.0:5000",
'workers': workers, "workers": workers,
'threads': threads, "threads": threads,
} }
gunicorn_app = GunicornApp(server.app, options) gunicorn_app = GunicornApp(server.app, options)
print(f'Starting server with {workers} workers and {threads} threads', flush=True) print(f"Starting server with {workers} workers and {threads} threads", flush=True)
gunicorn_app.run() gunicorn_app.run()

View File

@@ -37,7 +37,7 @@
<thead> <thead>
<tr> <tr>
<th>Date</th> <th>Date</th>
<th>Discussion Leader</th> <th>Discussion Leaders</th>
<th>Study Topic</th> <th>Study Topic</th>
</tr> </tr>
</thead> </thead>