install.sh: Python через apt-get, Python debs убраны

This commit is contained in:
root 2026-03-11 10:38:16 +00:00
parent 2f36aede2b
commit 023dfb95de
5 changed files with 11 additions and 24 deletions

View File

@ -1,6 +1,6 @@
# F7cloud Talk Recording — сборка для развёртывания
В репозитории собраны **все компоненты для работы сервиса**. Firefox ESR и GeckoDriver скопированы с машины сборки в `vendor/` и при развёртывании на другом сервере просто копируются из репо в `/opt/firefox-esr` и `/usr/local/bin/geckodriver`. Пакеты **xvfb**, **ffmpeg**, **python3.12** и **python3.12-venv** также включены в репозиторий в виде `.deb` (для Debian/Ubuntu) и при установке, при их отсутствии в системе, ставятся скриптом `install.sh` из `vendor/debs/` через `dpkg -i` (без доступа к внешним репозиториям).
В репозитории собраны **все компоненты для работы сервиса, кроме системных пакетов Python**. Firefox ESR и GeckoDriver скопированы с машины сборки в `vendor/` и при развёртывании на другом сервере просто копируются из репо в `/opt/firefox-esr` и `/usr/local/bin/geckodriver`. Пакеты **xvfb** и **ffmpeg** также включены в репозиторий в виде `.deb` (для Debian/Ubuntu) и при установке, при их отсутствии в системе, ставятся скриптом `install.sh` из `vendor/debs/` через `dpkg -i` (без доступа к внешним репозиториям). А вот **python3.12** и **python3.12-venv** ставятся через `apt-get` на целевой машине (если их ещё нет).
## Структура

View File

@ -17,7 +17,7 @@ fi
REPO_ROOT="$(cd "$(dirname "$0")" && pwd)"
echo "=== 1. Зависимости (только Python 3.12, xvfb, ffmpeg — остальное в репо) ==="
echo "=== 1. Зависимости (Python 3.12 через apt, xvfb/ffmpeg — из репо) ==="
NEED_PYTHON=0
NEED_XVFB=0
@ -33,29 +33,17 @@ if ! command -v ffmpeg >/dev/null 2>&1; then
NEED_FFMPEG=1
fi
# Пытаемся доустановить Python 3.12, xvfb и ffmpeg из vendor/debs, если они отсутствуют
# Пытаемся доустановить Python 3.12 через apt, если его нет
if [ "$NEED_PYTHON" -eq 1 ]; then
PY_DEB="$(ls "$REPO_ROOT"/vendor/debs/python3.12_[0-9]*.deb 2>/dev/null | head -n1 || true)"
PY_VENV_DEB="$(ls "$REPO_ROOT"/vendor/debs/python3.12-venv_[0-9]*.deb 2>/dev/null | head -n1 || true)"
if [ -n "$PY_DEB" ]; then
echo "python3.12 не найден в системе. Устанавливаю из $PY_DEB ..."
if dpkg -i "$PY_DEB"; then
echo "python3.12 успешно установлен из vendor/debs."
else
echo "Не удалось установить python3.12 из $PY_DEB. Проверьте зависимости пакета." >&2
fi
fi
if [ -n "$PY_VENV_DEB" ]; then
echo "python3.12-venv не найден в системе. Устанавливаю из $PY_VENV_DEB ..."
if dpkg -i "$PY_VENV_DEB"; then
echo "python3.12-venv успешно установлен из vendor/debs."
else
echo "Не удалось установить python3.12-venv из $PY_VENV_DEB. Проверьте зависимости пакета." >&2
fi
fi
echo "python3.12 не найден в системе. Попытка установки через apt-get (python3.12 python3.12-venv) ..."
if apt-get update -qq && apt-get install -y python3.12 python3.12-venv; then
if command -v python3.12 >/dev/null 2>&1; then
echo "python3.12 успешно установлен через apt-get."
NEED_PYTHON=0
fi
else
echo "Не удалось установить python3.12 через apt-get. Проверьте конфигурацию репозиториев." >&2
fi
fi
if [ "$NEED_XVFB" -eq 1 ]; then

3
vendor/README.md vendored
View File

@ -8,8 +8,7 @@
| **vendor/geckodriver/geckodriver** | Бинарь GeckoDriver для Linux. При деплое копируется в `/usr/local/bin/geckodriver`. |
| **vendor/debs/xvfb\_*.deb** | Debian-пакет `xvfb` для установки Xvfb на целевой машине (`dpkg -i` вызывается из `install.sh`, если Xvfb не найден). |
| **vendor/debs/ffmpeg\_*.deb** | Debian-пакет `ffmpeg` для установки ffmpeg на целевой машине (`dpkg -i` вызывается из `install.sh`, если ffmpeg не найден). |
| **vendor/debs/python3.12\_*.deb** | Debian-пакет `python3.12` для установки Python 3.12 на целевой машине (`dpkg -i` вызывается из `install.sh`, если `python3.12` не найден). |
| **vendor/debs/python3.12-venv\_*.deb** | Debian-пакет `python3.12-venv` для модуля venv (`dpkg -i` вызывается из `install.sh`, если модуль не установлен). |
| **Python 3.12** | Не включён в vendor — ставится через `apt-get install python3.12 python3.12-venv` на целевой машине (скрипт `install.sh` пытается сделать это автоматически и при ошибке выводит подсказку). |
## Обновление vendor/ (новая машина сборки)