You've already forked RekomenciBackend
Merge branch 'main' of gitlab.prodcontest.com:team-39/backend
This commit is contained in:
+12
-2
@@ -179,7 +179,7 @@ cache:
|
|||||||
policy: pull-push
|
policy: pull-push
|
||||||
before_script:
|
before_script:
|
||||||
- apt-get update
|
- apt-get update
|
||||||
- apt-get install -y --no-install-recommends ca-certificates curl just
|
- apt-get install -y --no-install-recommends ca-certificates curl just git
|
||||||
- update-ca-certificates
|
- update-ca-certificates
|
||||||
- curl -LsSf https://astral.sh/uv/install.sh | sh
|
- curl -LsSf https://astral.sh/uv/install.sh | sh
|
||||||
- export PATH="$HOME/.local/bin:$PATH"
|
- export PATH="$HOME/.local/bin:$PATH"
|
||||||
@@ -227,7 +227,7 @@ build-ml:
|
|||||||
<<: *build-config
|
<<: *build-config
|
||||||
variables:
|
variables:
|
||||||
IMAGE_NAME: $BASE_IMAGE_NAME/ml
|
IMAGE_NAME: $BASE_IMAGE_NAME/ml
|
||||||
CONTAINERFILE: Containerfile.ml
|
CONTAINERFILE: Containerfile
|
||||||
BUILDTARGET: ml
|
BUILDTARGET: ml
|
||||||
|
|
||||||
lint:
|
lint:
|
||||||
@@ -252,6 +252,8 @@ test:
|
|||||||
--profile migrations
|
--profile migrations
|
||||||
--profile tests
|
--profile tests
|
||||||
PODMAN_IGNORE_CGROUPSV1_WARNING: True
|
PODMAN_IGNORE_CGROUPSV1_WARNING: True
|
||||||
|
tags:
|
||||||
|
- self-hosted
|
||||||
script:
|
script:
|
||||||
- dnf -y install podman podman-compose
|
- dnf -y install podman podman-compose
|
||||||
# - cp ./infrastructure/configs/podman/ci.conf /etc/containers/containers.conf
|
# - cp ./infrastructure/configs/podman/ci.conf /etc/containers/containers.conf
|
||||||
@@ -348,6 +350,14 @@ sast-image-migrations:
|
|||||||
dependencies:
|
dependencies:
|
||||||
- build-migrations
|
- build-migrations
|
||||||
|
|
||||||
|
sast-image-ml:
|
||||||
|
<<: *trivy-image-scan
|
||||||
|
variables:
|
||||||
|
IMAGE_NAME: $BASE_IMAGE_NAME/ml
|
||||||
|
IMAGE_TYPE: ml
|
||||||
|
dependencies:
|
||||||
|
- build-ml
|
||||||
|
|
||||||
tag-runtime:
|
tag-runtime:
|
||||||
<<: *tag-config
|
<<: *tag-config
|
||||||
variables:
|
variables:
|
||||||
|
|||||||
+61
-32
@@ -1,7 +1,14 @@
|
|||||||
# syntax=docker/dockerfile:1.20
|
# syntax=docker/dockerfile:1.20
|
||||||
|
|
||||||
# Stage 1: Builder
|
ARG PY_IMAGE=python:3.12-slim
|
||||||
FROM docker.io/python:3.12-slim AS builder
|
|
||||||
|
# Stage 1: Base Builder
|
||||||
|
FROM ${PY_IMAGE} AS base-builder
|
||||||
|
|
||||||
|
RUN apt-get update && \
|
||||||
|
apt-get install -y --no-install-recommends \
|
||||||
|
curl git \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/
|
COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/
|
||||||
|
|
||||||
@@ -14,18 +21,30 @@ ENV PYTHONDONTWRITEBYTECODE=1 \
|
|||||||
UV_LINK_MODE=copy \
|
UV_LINK_MODE=copy \
|
||||||
UV_PROJECT_ENVIRONMENT=/opt/venv
|
UV_PROJECT_ENVIRONMENT=/opt/venv
|
||||||
|
|
||||||
RUN apt-get update && \
|
|
||||||
apt-get install -y --no-install-recommends \
|
|
||||||
curl git \
|
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
COPY pyproject.toml uv.lock ./
|
COPY pyproject.toml uv.lock ./
|
||||||
|
|
||||||
|
# Stage 2: Backend Builder
|
||||||
|
FROM base-builder AS backend-builder
|
||||||
|
|
||||||
|
COPY ./src ./src
|
||||||
|
|
||||||
RUN uv sync --frozen --no-dev --no-cache --group backend
|
RUN uv sync --frozen --no-dev --no-cache --group backend
|
||||||
|
|
||||||
|
# Stage 3: ML Builder
|
||||||
|
FROM base-builder AS ml-builder
|
||||||
|
|
||||||
# Stage 2: Runtime
|
COPY ./src ./src
|
||||||
FROM docker.io/python:3.12-alpine3.22 AS runtime
|
|
||||||
|
RUN uv sync --frozen --no-dev --no-cache --group ml
|
||||||
|
|
||||||
|
|
||||||
|
# Stage 4: Backend Runtime
|
||||||
|
FROM ${PY_IMAGE} AS runtime
|
||||||
|
|
||||||
|
RUN apt-get update && \
|
||||||
|
apt-get install -y --no-install-recommends \
|
||||||
|
curl \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
ENV PYTHONDONTWRITEBYTECODE=1 \
|
ENV PYTHONDONTWRITEBYTECODE=1 \
|
||||||
PYTHONUNBUFFERED=1 \
|
PYTHONUNBUFFERED=1 \
|
||||||
@@ -35,28 +54,22 @@ ENV PYTHONDONTWRITEBYTECODE=1 \
|
|||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
RUN apk add --no-cache --virtual .runtime-deps \
|
COPY --from=backend-builder /opt/venv /opt/venv
|
||||||
curl && \
|
|
||||||
rm -rf /var/cache/apk/*
|
|
||||||
|
|
||||||
RUN adduser -D -g '' app && chown -R app:app /app
|
COPY ./src/ ./
|
||||||
|
|
||||||
USER app
|
|
||||||
|
|
||||||
COPY --from=builder --chown=app:app /opt/venv /opt/venv
|
|
||||||
|
|
||||||
COPY --chown=app:app ./src/ ./
|
|
||||||
|
|
||||||
EXPOSE 8080
|
EXPOSE 8080
|
||||||
|
|
||||||
HEALTHCHECK --interval=30s --timeout=5s --start-period=5s --retries=3 \
|
CMD [ "/opt/venv/bin/web_api_cli", "/app/config.toml" ]
|
||||||
CMD curl -fsS http://localhost:8080/healthcheck || exit 1
|
|
||||||
|
|
||||||
CMD [ "web_api_cli", "/app/config.toml" ]
|
|
||||||
|
|
||||||
|
|
||||||
# Stage 3: Testing
|
# Stage 5: ML Runtime
|
||||||
FROM builder AS tests
|
FROM ${PY_IMAGE} AS ml
|
||||||
|
|
||||||
|
RUN apt-get update && \
|
||||||
|
apt-get install -y --no-install-recommends \
|
||||||
|
curl \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
ENV PYTHONDONTWRITEBYTECODE=1 \
|
ENV PYTHONDONTWRITEBYTECODE=1 \
|
||||||
PYTHONUNBUFFERED=1 \
|
PYTHONUNBUFFERED=1 \
|
||||||
@@ -66,21 +79,39 @@ ENV PYTHONDONTWRITEBYTECODE=1 \
|
|||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
RUN uv sync --no-install-project --group tests --frozen --no-cache
|
COPY --from=ml-builder /opt/venv /opt/venv
|
||||||
|
|
||||||
|
COPY ./src/ ./
|
||||||
|
|
||||||
|
EXPOSE 8081
|
||||||
|
|
||||||
|
CMD [ "/opt/venv/bin/ml_api_cli", "/app/config.toml" ]
|
||||||
|
|
||||||
|
|
||||||
|
# Stage 6: Testing
|
||||||
|
FROM base-builder AS tests
|
||||||
|
|
||||||
|
ENV PYTHONDONTWRITEBYTECODE=1 \
|
||||||
|
PYTHONUNBUFFERED=1 \
|
||||||
|
PYTHONOPTIMIZE=2 \
|
||||||
|
PATH="/opt/venv/bin:$PATH" \
|
||||||
|
PYTHONPATH="/app:$PYTHONPATH"
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
COPY ./src ./src
|
COPY ./src ./src
|
||||||
|
|
||||||
COPY ./tests ./tests
|
COPY ./tests ./tests
|
||||||
|
|
||||||
RUN uv pip install -e .
|
RUN uv sync --group tests --frozen --no-cache
|
||||||
|
|
||||||
RUN mkdir -p /app/cov && mkdir /app/cov/html
|
RUN mkdir -p /app/cov && mkdir /app/cov/html
|
||||||
|
|
||||||
CMD [ "sh", "-c", "coverage run --source=src -m pytest -v && coverage report > /app/cov/coverage.txt && coverage xml -o /app/cov/coverage.xml && coverage html -d /app/cov/html" ]
|
CMD [ "sh", "-c", "coverage run --source=src -m pytest -v && coverage report > /app/cov/coverage.txt && coverage xml -o /app/cov/coverage.xml && coverage html -d /app/cov/html" ]
|
||||||
|
|
||||||
|
|
||||||
# Stage 4: Migrations
|
# Stage 7: Migrations
|
||||||
FROM builder AS migrations
|
FROM base-builder AS migrations
|
||||||
|
|
||||||
ENV PYTHONDONTWRITEBYTECODE=1 \
|
ENV PYTHONDONTWRITEBYTECODE=1 \
|
||||||
PYTHONUNBUFFERED=1 \
|
PYTHONUNBUFFERED=1 \
|
||||||
@@ -92,14 +123,12 @@ WORKDIR /app
|
|||||||
|
|
||||||
RUN mkdir -p ./src/template_project
|
RUN mkdir -p ./src/template_project
|
||||||
|
|
||||||
RUN uv sync --no-install-project --group migrations --frozen --no-cache
|
|
||||||
|
|
||||||
COPY ./src ./src
|
COPY ./src ./src
|
||||||
|
|
||||||
COPY ./tests ./tests
|
COPY ./tests ./tests
|
||||||
|
|
||||||
COPY ./alembic.ini ./
|
COPY ./alembic.ini ./
|
||||||
|
|
||||||
RUN uv pip install -e .
|
RUN uv sync --group migrations --frozen --no-cache
|
||||||
|
|
||||||
CMD [ "alembic", "upgrade", "head" ]
|
CMD [ "alembic", "upgrade", "head" ]
|
||||||
|
|||||||
@@ -1,50 +0,0 @@
|
|||||||
# syntax=docker/dockerfile:1.20
|
|
||||||
|
|
||||||
ARG PY_IMAGE=docker.io/python:3.12-slim
|
|
||||||
|
|
||||||
# Stage 1: Builder
|
|
||||||
FROM ${PY_IMAGE} AS builder
|
|
||||||
|
|
||||||
RUN apt-get update && \
|
|
||||||
apt-get install -y --no-install-recommends \
|
|
||||||
curl git \
|
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/
|
|
||||||
|
|
||||||
WORKDIR /app
|
|
||||||
|
|
||||||
ENV PYTHONDONTWRITEBYTECODE=1 \
|
|
||||||
PYTHONUNBUFFERED=1 \
|
|
||||||
PYTHONOPTIMIZE=2 \
|
|
||||||
UV_COMPILE_BYTECODE=1 \
|
|
||||||
UV_LINK_MODE=copy \
|
|
||||||
UV_PROJECT_ENVIRONMENT=/opt/venv
|
|
||||||
|
|
||||||
COPY pyproject.toml uv.lock ./
|
|
||||||
|
|
||||||
RUN uv sync --frozen --no-dev --no-cache --group ml
|
|
||||||
|
|
||||||
# Stage 2: ML Runtime
|
|
||||||
FROM ${PY_IMAGE} AS ml
|
|
||||||
|
|
||||||
RUN apt-get update && \
|
|
||||||
apt-get install -y --no-install-recommends \
|
|
||||||
curl \
|
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
ENV PYTHONDONTWRITEBYTECODE=1 \
|
|
||||||
PYTHONUNBUFFERED=1 \
|
|
||||||
PYTHONOPTIMIZE=2 \
|
|
||||||
PATH="/opt/venv/bin:$PATH" \
|
|
||||||
PYTHONPATH="/app:$PYTHONPATH"
|
|
||||||
|
|
||||||
WORKDIR /app
|
|
||||||
|
|
||||||
COPY --from=builder /opt/venv /opt/venv
|
|
||||||
|
|
||||||
COPY ./src/ ./
|
|
||||||
|
|
||||||
EXPOSE 8081
|
|
||||||
|
|
||||||
CMD [ "/opt/venv/bin/ml_api_cli", "/app/config.toml" ]
|
|
||||||
@@ -78,6 +78,8 @@ services:
|
|||||||
retries: 5
|
retries: 5
|
||||||
networks:
|
networks:
|
||||||
- default
|
- default
|
||||||
|
profiles:
|
||||||
|
- ml
|
||||||
ports:
|
ports:
|
||||||
- name: web
|
- name: web
|
||||||
target: 8081
|
target: 8081
|
||||||
|
|||||||
Reference in New Issue
Block a user