funkčný template

This commit is contained in:
Alojz Masár
2026-02-15 17:18:12 +00:00
parent b962c1be7f
commit 8938b65685
10 changed files with 154 additions and 142 deletions

View File

@@ -1,4 +1,5 @@
PYTHON_BASE=3.13 PYTHON_BASE=3.13
DEVCONTAINER_IMAGE_REV=0.1
DEVCONTAINER_IMAGE_PULL_REPO=docker.masara.eu/python DEVCONTAINER_IMAGE_PULL_REPO=docker.masara.eu/python
DEVCONTAINER_IMAGE_PUSH_REPO=repo.masara.eu/python DEVCONTAINER_IMAGE_PUSH_REPO=repo.masara.eu/python
DEVCONTAINER_IMAGE_REV=0.1

View File

@@ -1,29 +1,29 @@
# Používame oficiálny Python image, ale env bude podobné ako v base:ubuntu # Používame oficiálny Python image, ale env bude podobné ako v base:ubuntu
ARG PYTHON_VERSION=3.13 ARG PYTHON_VERSION=3.13
FROM python:${PYTHON_VERSION}-slim FROM python:${PYTHON_VERSION}-slim
ENV PYTHONUNBUFFERED=1 \ ENV PYTHONUNBUFFERED=1 \
PIP_NO_CACHE_DIR=1 \ PIP_NO_CACHE_DIR=1 \
PIP_DISABLE_PIP_VERSION_CHECK=1 PIP_DISABLE_PIP_VERSION_CHECK=1
# Základ + Docker repo + docker-ce-cli + compose plugin + git # Základ + Docker repo + docker-ce-cli + compose plugin + git
RUN set -eux; \ RUN set -eux; \
apt-get update && \ apt-get update && \
DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \ DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \
ca-certificates curl gnupg && \ ca-certificates curl gnupg && \
install -m 0755 -d /etc/apt/keyrings && \ install -m 0755 -d /etc/apt/keyrings && \
curl -fsSL https://download.docker.com/linux/debian/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg && \ curl -fsSL https://download.docker.com/linux/debian/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg && \
chmod a+r /etc/apt/keyrings/docker.gpg && \ chmod a+r /etc/apt/keyrings/docker.gpg && \
echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] \ echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] \
https://download.docker.com/linux/debian $(. /etc/os-release && echo $VERSION_CODENAME) stable" \ https://download.docker.com/linux/debian $(. /etc/os-release && echo $VERSION_CODENAME) stable" \
> /etc/apt/sources.list.d/docker.list && \ > /etc/apt/sources.list.d/docker.list && \
apt-get update && \ apt-get update && \
DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \ DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \
build-essential pkg-config \ build-essential pkg-config \
git \ git \
docker-ce-cli docker-compose-plugin docker-buildx-plugin \ docker-ce-cli docker-compose-plugin docker-buildx-plugin \
libatomic1 libstdc++6 libgcc-s1 \ libatomic1 libstdc++6 libgcc-s1 \
procps \ procps \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
WORKDIR /workspace WORKDIR /workspace

View File

@@ -1,49 +1,53 @@
{ {
"name": "Python Dev", "name": "Python Dev",
"dockerComposeFile": "docker-compose.yml", "containerEnv": {
"service": "dev", "PIP_INDEX_URL": "https://dv.masara.eu/repository/pypi-group/simple",
"containerEnv": { "PIP_ROOT_USER_ACTION": "ignore"
"PIP_INDEX_URL": "https://dv.masara.eu/repository/pypi-group/simple", },
"PIP_ROOT_USER_ACTION": "ignore" "remoteEnv": {
}, "DOCKER_BUILDKIT": "1",
"remoteEnv": { "VIRTUAL_ENV": "/workspace/.venv",
"DOCKER_BUILDKIT": "1" "PATH": "/workspace/.venv/bin:${containerEnv:PATH}"
}, },
"workspaceFolder": "/workspace", "workspaceFolder": "/workspace",
"remoteUser": "root", "remoteUser": "root",
"customizations": { "overrideCommand": true,
"vscode": { "customizations": {
"extensions": [ "vscode": {
"ms-python.python", "extensions": [
"ms-python.vscode-pylance", "ms-python.python",
"ms-toolsai.jupyter", "ms-python.vscode-pylance",
"ms-python.black-formatter", "ms-toolsai.jupyter",
"ms-python.isort", "ms-python.black-formatter",
"ms-azuretools.vscode-docker" "ms-python.isort",
], "ms-azuretools.vscode-docker",
"settings": { "openai.chatgpt"
"python.formatting.provider": "black", ],
"python.analysis.extraPaths": [ "settings": {
"${workspaceFolder}/app" "python.formatting.provider": "black",
], "python.analysis.extraPaths": [
"editor.formatOnSave": true, "${workspaceFolder}/app"
"python.terminal.activateEnvironment": true, ],
"python.defaultInterpreterPath": ".venv/bin/python", "editor.formatOnSave": true,
"remote.restoreForwardedPorts": false, "python.terminal.activateEnvironment": true,
"remote.autoForwardPortsSource": "output", "python.defaultInterpreterPath": ".venv/bin/python",
"debug.javascript.autoAttachFilter": "disabled" "remote.restoreForwardedPorts": false,
} "remote.autoForwardPortsSource": "output",
} "debug.javascript.autoAttachFilter": "disabled"
}, }
"mounts": [ }
"type=bind,source=/var/run/docker.sock,target=/var/run/docker.sock" },
], "mounts": [
"postCreateCommand": "bash .devcontainer/post_create.sh", "type=bind,source=/var/run/docker.sock,target=/var/run/docker.sock",
"forwardPorts": [ "type=bind,source=${localEnv:USERPROFILE}/.codex,target=/root/.codex"
], ],
"portsAttributes": { "postCreateCommand": "bash .devcontainer/post_create.sh",
"*": { "forwardPorts": [],
"onAutoForward": "ignore" "portsAttributes": {
} "*": {
} "onAutoForward": "ignore"
} }
},
"image": "docker.masara.eu/python:3.13-0.1-devcontainer",
"workspaceMount": "source=${localWorkspaceFolder},target=/workspace,type=bind,consistency=cached"
}

View File

@@ -1,9 +1,11 @@
services: services:
dev: dev:
image: ${DEVCONTAINER_IMAGE_PULL_REPO}:${PYTHON_BASE}-${DEVCONTAINER_IMAGE_REV}-devcontainer image: ${DEVCONTAINER_IMAGE_PULL_REPO}:${PYTHON_BASE}-${DEVCONTAINER_IMAGE_REV}-devcontainer
pull_policy: always pull_policy: always
init: true init: true
command: sleep infinity
tty: true
volumes: volumes:
- ..:/workspace:cached - ..:/workspace:cached
environment: environment:
PYTHON_BASE: ${PYTHON_BASE} PYTHON_BASE: ${PYTHON_BASE}

View File

@@ -7,24 +7,29 @@ VENV_PATH="/workspace/.venv"
if [ ! -d "$VENV_PATH" ]; then if [ ! -d "$VENV_PATH" ]; then
echo "Virtuálne prostredie neexistuje vytváram..." echo "Virtuálne prostredie neexistuje vytváram..."
python -m venv "$VENV_PATH" python -m venv "$VENV_PATH"
echo "Aktivujem virtuálne prostredie..."
# shellcheck disable=SC1090
source "$VENV_PATH/bin/activate"
echo "Aktualizujem pip a základné nástroje..."
pip install --upgrade pip setuptools wheel
else else
echo "Používam existujúce virtuálne prostredie..." echo "Používam existujúce virtuálne prostredie..."
# shellcheck disable=SC1090
# source "$VENV_PATH/bin/activate"
fi fi
echo "Aktivujem virtuálne prostredie..."
# shellcheck disable=SC1090
source "$VENV_PATH/bin/activate"
echo "Aktualizujem pip a základné nástroje..."
python -m pip install --upgrade pip setuptools wheel
# Inštalácia závislostí, ak existuje requirements.txt # Inštalácia závislostí, ak existuje requirements.txt
if [ -f "/workspace/requirements.txt" ]; then if [ -f "/workspace/requirements.txt" ]; then
echo "Inštalujem závislosti z requirements.txt..." echo "Inštalujem závislosti z requirements.txt..."
pip install -r /workspace/requirements.txt python -m pip install -r /workspace/requirements.txt
else else
echo "requirements.txt nenájdený preskakujem inštaláciu závislostí." echo "requirements.txt nenájdený preskakujem inštaláciu závislostí."
fi fi
# Ak sa terminál otvorí skôr, než Python extension stihne auto-aktiváciu,
# zabezpečíme aktiváciu aj cez shell init.
BASHRC="/root/.bashrc"
ACTIVATE_LINE='[ -f /workspace/.venv/bin/activate ] && source /workspace/.venv/bin/activate'
if ! grep -Fq "$ACTIVATE_LINE" "$BASHRC"; then
echo "$ACTIVATE_LINE" >> "$BASHRC"
fi

View File

@@ -1,16 +1,16 @@
__pycache__ __pycache__
*.pyc *.pyc
*.pyo *.pyo
*.pyd *.pyd
*.db *.db
*.sqlite3 *.sqlite3
.env .env
*.log *.log
.git .git
.gitignore .gitignore
.vscode .vscode
.venv .venv
venv venv
rest rest
docker docker

2
.vscode/tasks.json vendored
View File

@@ -27,4 +27,4 @@
"problemMatcher": [] "problemMatcher": []
} }
] ]
} }

View File

@@ -1,32 +1,32 @@
# syntax=docker/dockerfile:1.6 # syntax=docker/dockerfile:1.6
ARG PYTHON_BASE=3.13 ARG PYTHON_BASE=3.13
FROM python:${PYTHON_BASE}-slim FROM python:${PYTHON_BASE}-slim
ENV PYTHONDONTWRITEBYTECODE=1 \ ENV PYTHONDONTWRITEBYTECODE=1 \
PYTHONUNBUFFERED=1 \ PYTHONUNBUFFERED=1 \
PIP_NO_CACHE_DIR=1 \ PIP_NO_CACHE_DIR=1 \
PIP_DISABLE_PIP_VERSION_CHECK=1 \ PIP_DISABLE_PIP_VERSION_CHECK=1 \
PIP_INDEX_URL=https://dv.masara.eu/repository/pypi-group/simple \ PIP_INDEX_URL=https://dv.masara.eu/repository/pypi-group/simple \
PIP_NO_INPUT=1 PIP_NO_INPUT=1
WORKDIR /app WORKDIR /app
# Inštalácia závislostí # Inštalácia závislostí
COPY requirements.txt . COPY requirements.txt .
RUN --mount=type=cache,target=/root/.cache/pip \ RUN --mount=type=cache,target=/root/.cache/pip \
pip install -r requirements.txt pip install -r requirements.txt
# Kopírovanie zdrojov # Kopírovanie zdrojov
COPY app/ /app/ COPY app/ /app/
# Vytvorenie ne-root usera # Vytvorenie ne-root usera
ARG APP_USER_ID=1000 ARG APP_USER_ID=1000
RUN useradd -u ${APP_USER_ID} -m appuser && \ RUN useradd -u ${APP_USER_ID} -m appuser && \
chown -R appuser:appuser /app chown -R appuser:appuser /app
USER appuser USER appuser
# Príklad spustenia # Príklad spustenia
# EXPOSE 8080 # EXPOSE 8080
# CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8080"] # CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8080"]

View File

@@ -1,2 +1,2 @@
# hello_world.py # hello_world.py
print("Hello, world!") print("Hello, world!")

View File

@@ -71,4 +71,4 @@ if ($LASTEXITCODE -ne 0) {
if ($Push) { if ($Push) {
Invoke-DockerPushWithLoginFallback -Tag $versionTag -Registry $registry Invoke-DockerPushWithLoginFallback -Tag $versionTag -Registry $registry
Invoke-DockerPushWithLoginFallback -Tag $channelTag -Registry $registry Invoke-DockerPushWithLoginFallback -Tag $channelTag -Registry $registry
} }