funkčný template
This commit is contained in:
@@ -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
|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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"
|
||||||
|
}
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
2
.vscode/tasks.json
vendored
@@ -27,4 +27,4 @@
|
|||||||
"problemMatcher": []
|
"problemMatcher": []
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
64
Dockerfile
64
Dockerfile
@@ -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"]
|
||||||
|
|||||||
@@ -1,2 +1,2 @@
|
|||||||
# hello_world.py
|
# hello_world.py
|
||||||
print("Hello, world!")
|
print("Hello, world!")
|
||||||
@@ -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
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user