Some checks failed
Ansible Testing / lint (push) Has been cancelled
Ansible Testing / test (default) (push) Has been cancelled
Ansible Testing / test (minimal) (push) Has been cancelled
Ansible Testing / test (performance) (push) Has been cancelled
Ansible Testing / deploy-check (push) Has been cancelled
- Убраны пакеты: vim, jq, git, htop, tree из всех Dockerfile - Закомментированы установки Docker, Docker Compose, yq - Обновлен Rocky Linux до версии 9 с Python 3 - Исправлена проблема с passlib в ansible-controller - Оставлены только необходимые пакеты: systemd, curl, wget, nano, python3, sudo
53 lines
1.9 KiB
Docker
53 lines
1.9 KiB
Docker
# RED OS с systemd
|
||
# Автор: Сергей Антропов
|
||
# Сайт: https://devops.org.ru
|
||
# https://registry.red-soft.ru/ubi7/ubi/tags
|
||
# docker search registry.red-soft.ru/ubi7/ubi
|
||
|
||
FROM registry.red-soft.ru/ubi7/ubi
|
||
|
||
# Обновляем систему
|
||
RUN dnf update -y && dnf upgrade -y
|
||
|
||
# Устанавливаем systemd и необходимые пакеты
|
||
RUN dnf install -y \
|
||
systemd \
|
||
systemd-sysv \
|
||
dbus \
|
||
curl \
|
||
wget \
|
||
nano \
|
||
python3 \
|
||
python3-pip \
|
||
sudo \
|
||
&& dnf clean all
|
||
|
||
# Устанавливаем yq (автоопределение архитектуры)
|
||
# RUN ARCH=$(uname -m | sed 's/x86_64/amd64/; s/aarch64/arm64/') && \
|
||
# wget -qO /usr/local/bin/yq "https://github.com/mikefarah/yq/releases/latest/download/yq_linux_${ARCH}" && \
|
||
# chmod +x /usr/local/bin/yq
|
||
|
||
# Устанавливаем Docker вручную для RED OS
|
||
# RUN dnf install -y dnf-plugins-core \
|
||
# && dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo \
|
||
# && dnf install -y docker-ce docker-ce-cli containerd.io \
|
||
# && dnf clean all
|
||
|
||
# Устанавливаем 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
|
||
|
||
# Настраиваем systemd
|
||
RUN systemctl set-default multi-user.target
|
||
|
||
# Настраиваем sudoers для root и пользователей
|
||
RUN echo "root ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers && \
|
||
echo "ALL ALL=(ALL) NOPASSWD:ALL" > /etc/sudoers.d/ansible-test
|
||
|
||
# Создаем пользователя для Ansible
|
||
RUN useradd -m -s /bin/bash ansible \
|
||
&& echo "ansible ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers
|
||
|
||
# Команда по умолчанию (система запускается от root для systemd)
|
||
CMD ["/sbin/init"]
|