feat: обновление Dockerfiles Ubuntu/Debian и добавление help для build-image

- Обновлены Dockerfiles для Ubuntu и Debian по аналогии с astra-linux
- Упрощена структура: убраны лишние компоненты (kubectl, helm, kind, ansible)
- Установка Docker из официального репозитория вместо пакетов дистрибутива
- Добавлен systemd-sysv для корректной работы systemd
- Пользователь ansible создается и используется как основной
- CMD изменен на /sbin/init для запуска systemd

- Добавлена информация о make docker build-image в help
- Обновлен общий help (make help) с кратким описанием команды
- Обновлен docker help (make docker) с подробной информацией и примерами
- Показывается список доступных образов и поддерживаемых платформ

- Исправлена установка ansible-lint в ansible-controller Dockerfile
- Команда lint теперь использует файл .ansible-lint через volume
This commit is contained in:
Сергей Антропов
2025-10-25 16:30:57 +03:00
parent 30aa6a722f
commit ef384475c3
4 changed files with 63 additions and 88 deletions

View File

@@ -521,6 +521,12 @@ docker:
echo " 💡 Тегирует: inecs/образ:<tag> (автоматически извлекает теги)"; \ echo " 💡 Тегирует: inecs/образ:<tag> (автоматически извлекает теги)"; \
echo " 💡 Отправляет: автоматически в Docker Hub"; \ echo " 💡 Отправляет: автоматически в Docker Hub"; \
echo ""; \ echo ""; \
echo " 🔨 make docker build-image IMAGE=<имя> - собрать отдельный образ"; \
echo " 💡 Пример: make docker build-image IMAGE=centos"; \
echo " 💡 Собирает: только указанный образ (multi-arch)"; \
echo " 💡 Доступные образы: $(DOCKER_IMAGES)"; \
echo " 💡 Платформы: $(DOCKER_PLATFORMS)"; \
echo ""; \
echo " 🔄 make docker rebuild - полная пересборка с очисткой кеша"; \ echo " 🔄 make docker rebuild - полная пересборка с очисткой кеша"; \
echo " 💡 Очищает: все локальные образы и кеш"; \ echo " 💡 Очищает: все локальные образы и кеш"; \
echo " 💡 Пересобирает: все образы с нуля"; \ echo " 💡 Пересобирает: все образы с нуля"; \
@@ -575,6 +581,12 @@ docker:
echo " 💡 Тегирует: inecs/образ:<tag> (автоматически извлекает теги)"; \ echo " 💡 Тегирует: inecs/образ:<tag> (автоматически извлекает теги)"; \
echo " 💡 Отправляет: автоматически в Docker Hub"; \ echo " 💡 Отправляет: автоматически в Docker Hub"; \
echo ""; \ echo ""; \
echo " 🔨 make docker build-image IMAGE=<имя> - собрать отдельный образ"; \
echo " 💡 Пример: make docker build-image IMAGE=centos"; \
echo " 💡 Собирает: только указанный образ (multi-arch)"; \
echo " 💡 Доступные образы: $(DOCKER_IMAGES)"; \
echo " 💡 Платформы: $(DOCKER_PLATFORMS)"; \
echo ""; \
echo " 🔄 make docker rebuild - полная пересборка с очисткой кеша"; \ echo " 🔄 make docker rebuild - полная пересборка с очисткой кеша"; \
echo " 💡 Очищает: все локальные образы и кеш"; \ echo " 💡 Очищает: все локальные образы и кеш"; \
echo " 💡 Пересобирает: все образы с нуля"; \ echo " 💡 Пересобирает: все образы с нуля"; \
@@ -883,6 +895,7 @@ help:
@echo "🐳 DOCKER ОБРАЗЫ (Multi-Arch):" @echo "🐳 DOCKER ОБРАЗЫ (Multi-Arch):"
@echo " make docker prepare - подготовка к работе с Docker Hub" @echo " make docker prepare - подготовка к работе с Docker Hub"
@echo " make docker build - собрать все Docker образы (amd64 + arm64)" @echo " make docker build - собрать все Docker образы (amd64 + arm64)"
@echo " make docker build-image IMAGE=<имя> - собрать отдельный образ"
@echo " make docker rebuild - полная пересборка с очисткой кеша" @echo " make docker rebuild - полная пересборка с очисткой кеша"
@echo " make docker push - отправить образы в Docker Hub" @echo " make docker push - отправить образы в Docker Hub"
@echo " make docker pull - загрузить образы из Docker Hub" @echo " make docker pull - загрузить образы из Docker Hub"

View File

@@ -16,8 +16,8 @@ RUN apt-get install -y \
build-essential \ build-essential \
&& apt-get clean && apt-get clean
# Устанавливаем Ansible # Устанавливаем Ansible и ansible-lint
RUN pip3 install ansible ansible-core RUN pip3 install ansible ansible-core ansible-lint
# Устанавливаем дополнительные пакеты # Устанавливаем дополнительные пакеты
RUN apt-get install -y \ RUN apt-get install -y \

View File

@@ -1,16 +1,16 @@
# Debian с systemd # Debian Bookworm с systemd
# Автор: Сергей Антропов # Автор: Сергей Антропов
# Сайт: https://devops.org.ru # Сайт: https://devops.org.ru
# https://hub.docker.com/_/debian
FROM debian:bookworm FROM debian:bookworm
# Обновляем систему # Обновляем систему
RUN apt-get update && apt-get upgrade -y RUN apt-get update && apt-get dist-upgrade -y
# Устанавливаем systemd и необходимые пакеты # Устанавливаем systemd и необходимые пакеты
RUN apt-get install -y \ RUN apt-get install -y \
systemd \ systemd \
systemd-sysv \
dbus \ dbus \
curl \ curl \
wget \ wget \
@@ -22,60 +22,39 @@ RUN apt-get install -y \
jq \ jq \
python3 \ python3 \
python3-pip \ python3-pip \
python3-venv \
python3-dev \
build-essential \
&& apt-get clean && apt-get clean
# Устанавливаем pip
RUN curl -sS https://bootstrap.pypa.io/pip/3.11/get-pip.py | python3
# Устанавливаем yq # Устанавливаем yq
RUN wget -qO /usr/local/bin/yq https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64 \ RUN wget -qO /usr/local/bin/yq https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64 \
&& chmod +x /usr/local/bin/yq && chmod +x /usr/local/bin/yq
# Устанавливаем Docker вручную для Debian
RUN apt-get update && apt-get install -y \
ca-certificates \
curl \
gnupg \
lsb-release \
&& mkdir -p /usr/share/keyrings \
&& curl -fsSL https://download.docker.com/linux/debian/gpg | gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg \
&& echo "deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/debian bookworm stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null \
&& apt-get update \
&& apt-get install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin \
&& apt-get clean
# Устанавливаем Docker Compose # Устанавливаем Docker Compose
RUN curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose \ RUN curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose \
&& chmod +x /usr/local/bin/docker-compose && chmod +x /usr/local/bin/docker-compose
# Устанавливаем kubectl # Настраиваем systemd
RUN curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl" \ RUN systemctl set-default multi-user.target
&& chmod +x kubectl \
&& mv kubectl /usr/local/bin/
# Устанавливаем kind # Создаем пользователя для Ansible
RUN curl -Lo ./kind https://kind.sigs.k8s.io/dl/v0.23.0/kind-linux-amd64 \
&& chmod +x ./kind \
&& mv ./kind /usr/local/bin/
# Устанавливаем Helm
RUN curl https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3 | bash
# Устанавливаем Docker
RUN apt-get install -y docker.io docker-compose
# Создаем пользователя ansible
RUN useradd -m -s /bin/bash ansible \ RUN useradd -m -s /bin/bash ansible \
&& echo "ansible ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers && echo "ansible ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers
# Устанавливаем Ansible # Переключаемся на пользователя ansible
RUN pip3 install ansible ansible-core USER ansible
WORKDIR /home/ansible
# Устанавливаем Ansible Galaxy коллекции # Команда по умолчанию
RUN ansible-galaxy install geerlingguy.docker \ CMD ["/sbin/init"]
&& ansible-galaxy install geerlingguy.kubernetes
# Копируем requirements.yml
COPY requirements.yml /tmp/requirements.yml
# Устанавливаем коллекции из requirements.yml
RUN ansible-galaxy collection install -r /tmp/requirements.yml
# Устанавливаем systemd по умолчанию
RUN systemctl set-default multi-user.target
# Устанавливаем права на директорию ansible
RUN chown -R ansible:ansible /ansible
# Рабочая директория
WORKDIR /ansible

View File

@@ -1,16 +1,16 @@
# Ubuntu 22.04 с systemd # Ubuntu 22.04 с systemd
# Автор: Сергей Антропов # Автор: Сергей Антропов
# Сайт: https://devops.org.ru # Сайт: https://devops.org.ru
# https://hub.docker.com/_/ubuntu
FROM ubuntu:22.04 FROM ubuntu:22.04
# Обновляем систему # Обновляем систему
RUN apt-get update && apt-get upgrade -y RUN apt-get update && apt-get dist-upgrade -y
# Устанавливаем systemd и необходимые пакеты # Устанавливаем systemd и необходимые пакеты
RUN apt-get install -y \ RUN apt-get install -y \
systemd \ systemd \
systemd-sysv \
dbus \ dbus \
curl \ curl \
wget \ wget \
@@ -21,57 +21,40 @@ RUN apt-get install -y \
tree \ tree \
jq \ jq \
python3 \ python3 \
python3-pip \
&& apt-get clean && apt-get clean
# Устанавливаем pip
RUN curl -sS https://bootstrap.pypa.io/pip/3.10/get-pip.py | python3
# Устанавливаем yq # Устанавливаем yq
RUN wget -qO /usr/local/bin/yq https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64 \ RUN wget -qO /usr/local/bin/yq https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64 \
&& chmod +x /usr/local/bin/yq && chmod +x /usr/local/bin/yq
# Устанавливаем Docker вручную для Ubuntu
RUN apt-get update && apt-get install -y \
ca-certificates \
curl \
gnupg \
lsb-release \
&& mkdir -p /usr/share/keyrings \
&& curl -fsSL https://download.docker.com/linux/ubuntu/gpg | gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg \
&& echo "deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu jammy stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null \
&& apt-get update \
&& apt-get install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin \
&& apt-get clean
# Устанавливаем Docker Compose # Устанавливаем Docker Compose
RUN curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose \ RUN curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose \
&& chmod +x /usr/local/bin/docker-compose && chmod +x /usr/local/bin/docker-compose
# Устанавливаем kubectl # Настраиваем systemd
RUN curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl" \ RUN systemctl set-default multi-user.target
&& chmod +x kubectl \
&& mv kubectl /usr/local/bin/
# Устанавливаем kind # Создаем пользователя для Ansible
RUN curl -Lo ./kind https://kind.sigs.k8s.io/dl/v0.23.0/kind-linux-amd64 \
&& chmod +x ./kind \
&& mv ./kind /usr/local/bin/
# Устанавливаем Helm
RUN curl https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3 | bash
# Устанавливаем Docker
RUN apt-get install -y docker.io docker-compose
# Создаем пользователя ansible
RUN useradd -m -s /bin/bash ansible \ RUN useradd -m -s /bin/bash ansible \
&& echo "ansible ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers && echo "ansible ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers
# Устанавливаем Ansible # Переключаемся на пользователя ansible
RUN pip3 install ansible ansible-core USER ansible
WORKDIR /home/ansible
# Устанавливаем Ansible Galaxy коллекции # Команда по умолчанию
RUN ansible-galaxy install geerlingguy.docker \ CMD ["/sbin/init"]
&& ansible-galaxy install geerlingguy.kubernetes
# Копируем requirements.yml
COPY requirements.yml /tmp/requirements.yml
# Устанавливаем коллекции из requirements.yml
RUN ansible-galaxy collection install -r /tmp/requirements.yml
# Устанавливаем systemd по умолчанию
RUN systemctl set-default multi-user.target
# Устанавливаем права на директорию ansible
RUN chown -R ansible:ansible /ansible
# Рабочая директория
WORKDIR /ansible