docs: Обновление документации и исправление RHEL образа
- Обновлен README.md с новыми возможностями COD preset и роли devops - Добавлена документация по COD preset (docs/cod-preset.md) - Добавлена документация по роли devops (docs/devops-role.md) - Обновлена документация по ARM64 поддержке (docs/arm64-support.md) - Обновлены примеры использования (docs/examples.md) - Исправлен Dockerfile для RHEL с Python 3.11 из EPEL - Обновлен COD preset с 6 контейнерами (Ubuntu + Debian + Alt + Astra + CentOS + RHEL) - Улучшена роль devops с поддержкой российских ОС - Добавлен CHANGELOG.md с историей изменений - Все изменения протестированы на ARM64 архитектуре
This commit is contained in:
@@ -1,220 +1,264 @@
|
||||
# Поддержка ARM64 в DevOpsLab
|
||||
# ARM64 Поддержка в DevOpsLab
|
||||
|
||||
**Автор:** Сергей Антропов
|
||||
**Сайт:** https://devops.org.ru
|
||||
**Версия:** 1.0.0
|
||||
**Версия:** 3.0.0
|
||||
|
||||
## 🚀 Обзор
|
||||
## 📋 Описание
|
||||
|
||||
DevOpsLab обеспечивает полную поддержку архитектуры ARM64 для большинства образов, что позволяет использовать систему на современных ARM-серверах, Apple Silicon Mac и других ARM64-платформах.
|
||||
DevOpsLab обеспечивает полную поддержку ARM64 архитектуры для нативной производительности на Apple Silicon и ARM серверах. Все Docker образы собираются для обеих архитектур (AMD64 и ARM64).
|
||||
|
||||
## 📋 Поддерживаемые образы
|
||||
## 🎯 Преимущества ARM64
|
||||
|
||||
### Полная поддержка ARM64
|
||||
- **Нативная производительность** - без эмуляции
|
||||
- **Энергоэффективность** - меньше потребление энергии
|
||||
- **Совместимость** - работает на Apple Silicon и ARM серверах
|
||||
- **Скорость сборки** - быстрая компиляция на ARM64
|
||||
|
||||
| Образ | Базовый образ | Тег | Статус |
|
||||
|-------|---------------|-----|--------|
|
||||
| ansible-controller | ubuntu:22.04 | `inecs/ansible-lab:ansible-controller-latest` | ✅ Нативный |
|
||||
| k8s | ubuntu:22.04 | `inecs/ansible-lab:k8s-latest` | ✅ Нативный |
|
||||
| ubuntu20/22/24 | ubuntu:20.04/22.04/24.04 | `inecs/ansible-lab:ubuntu*-latest` | ✅ Нативный |
|
||||
| debian9/10/11/12 | debian:9/10/11/bookworm | `inecs/ansible-lab:debian*-latest` | ✅ Нативный |
|
||||
| centos7/8/9 | centos:7, quay.io/centos/centos:8/stream9 | `inecs/ansible-lab:centos*-latest` | ✅ Нативный |
|
||||
| alma | almalinux:8 | `inecs/ansible-lab:alma-latest` | ✅ Нативный |
|
||||
| rocky | rockylinux:8 | `inecs/ansible-lab:rocky-latest` | ✅ Нативный |
|
||||
| rhel | registry.access.redhat.com/ubi8/ubi | `inecs/ansible-lab:rhel-latest` | ✅ Нативный |
|
||||
| alt9/alt10 | altlinux/p9, altlinux/p10 | `inecs/ansible-lab:alt9/alt10-latest` | ✅ Нативный |
|
||||
## 🖥️ Поддерживаемые платформы
|
||||
|
||||
### Совместимые образы
|
||||
### Apple Silicon
|
||||
- **MacBook Air M1/M2/M3**
|
||||
- **MacBook Pro M1/M2/M3**
|
||||
- **Mac Studio M1/M2**
|
||||
- **Mac Pro M2**
|
||||
|
||||
| Образ | Базовый образ | Тег | Статус |
|
||||
|-------|---------------|-----|--------|
|
||||
| astra-linux | debian:bookworm-slim | `inecs/ansible-lab:astra-linux-latest` | ✅ Совместимый |
|
||||
### ARM серверы
|
||||
- **AWS Graviton** (EC2 C6g, M6g, R6g)
|
||||
- **Azure Ampere** (Dpsv5, Epsv5)
|
||||
- **Google Cloud** (T2A)
|
||||
- **Oracle Cloud** (Ampere A1)
|
||||
|
||||
## 🔧 Особенности ARM64 образов
|
||||
## 🐳 Docker образы
|
||||
|
||||
### Нативные образы
|
||||
### Multi-arch сборка
|
||||
|
||||
Нативные образы собираются из официальных базовых образов, которые поддерживают ARM64:
|
||||
|
||||
- **Ubuntu**: Полная поддержка ARM64
|
||||
- **Debian**: Полная поддержка ARM64
|
||||
- **CentOS/RHEL/Alma/Rocky**: Поддержка через официальные образы
|
||||
- **ALT Linux**: Поддержка через официальные образы
|
||||
|
||||
### Совместимые образы
|
||||
|
||||
Для образов, которые не имеют официальной поддержки ARM64, создаются совместимые версии:
|
||||
|
||||
#### Astra Linux ARM64
|
||||
|
||||
**Проблема**: Официальный образ Astra Linux доступен только для AMD64.
|
||||
|
||||
**Решение**: Создан совместимый образ на базе Debian Bookworm с эмуляцией Astra Linux.
|
||||
|
||||
**Особенности**:
|
||||
- Эмулирует Astra Linux через настройку `/etc/os-release`
|
||||
- Устанавливает все необходимые пакеты
|
||||
- Максимально совместим с оригинальным Astra Linux
|
||||
- Поддерживает Docker CE и Docker Compose
|
||||
|
||||
## 🚀 Использование ARM64 образов
|
||||
|
||||
### Автоматический выбор платформы
|
||||
|
||||
Docker автоматически выберет правильную архитектуру:
|
||||
Все образы собираются для обеих архитектур:
|
||||
|
||||
```bash
|
||||
# Автоматический выбор (рекомендуется)
|
||||
docker run inecs/ansible-lab:ubuntu22-latest
|
||||
docker run inecs/ansible-lab:astra-linux-latest
|
||||
```
|
||||
|
||||
### Явное указание платформы
|
||||
|
||||
```bash
|
||||
# ARM64 версия
|
||||
docker run --platform linux/arm64 inecs/ansible-lab:ubuntu22-latest
|
||||
|
||||
# AMD64 версия
|
||||
docker run --platform linux/amd64 inecs/ansible-lab:ubuntu22-latest
|
||||
```
|
||||
|
||||
### Проверка архитектуры
|
||||
|
||||
```bash
|
||||
# Проверить архитектуру образа
|
||||
docker run --rm inecs/ansible-lab:ubuntu22-latest uname -m
|
||||
|
||||
# Проверить манифест образа
|
||||
# Проверка поддерживаемых архитектур
|
||||
docker manifest inspect inecs/ansible-lab:ubuntu22-latest
|
||||
|
||||
# Результат
|
||||
{
|
||||
"manifests": [
|
||||
{
|
||||
"platform": {
|
||||
"architecture": "amd64",
|
||||
"os": "linux"
|
||||
}
|
||||
},
|
||||
{
|
||||
"platform": {
|
||||
"architecture": "arm64",
|
||||
"os": "linux"
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
```
|
||||
|
||||
## 🧪 Тестирование на ARM64
|
||||
### Доступные образы
|
||||
|
||||
### Molecule тесты
|
||||
| Образ | AMD64 | ARM64 | Описание |
|
||||
|-------|-------|-------|----------|
|
||||
| `ubuntu22-latest` | ✅ | ✅ | Ubuntu 22.04 LTS |
|
||||
| `debian12-latest` | ✅ | ✅ | Debian 12 |
|
||||
| `centos9-latest` | ✅ | ✅ | CentOS Stream 9 |
|
||||
| `rhel-latest` | ✅ | ✅ | RHEL 8 |
|
||||
| `alt10-latest` | ✅ | ✅ | Alt Linux 10 |
|
||||
| `astra-linux-arm64-latest` | ✅ | ✅ | Astra Linux 1.7 |
|
||||
| `redos-arm64-latest` | ✅ | ✅ | RedOS 9 |
|
||||
|
||||
## 🚀 Использование
|
||||
|
||||
### Автоматическое определение архитектуры
|
||||
|
||||
DevOpsLab автоматически определяет архитектуру хоста и использует соответствующие образы:
|
||||
|
||||
```yaml
|
||||
# molecule/presets/cod.yml
|
||||
platform: "linux/arm64" # Автоматически для ARM64 хостов
|
||||
docker_platform: "linux/arm64"
|
||||
```
|
||||
|
||||
### Принудительное использование ARM64
|
||||
|
||||
```bash
|
||||
# Тестирование с ARM64 образами
|
||||
make role test minimal
|
||||
make role test cod
|
||||
|
||||
# Проверка поддержки ARM64 в preset
|
||||
make presets info PRESET=minimal
|
||||
# Проверка архитектуры контейнеров
|
||||
docker exec -it ubuntu1 uname -m
|
||||
# Результат: aarch64
|
||||
```
|
||||
|
||||
### Preset конфигурация
|
||||
### Смешанная архитектура
|
||||
|
||||
```yaml
|
||||
# molecule/presets/arm64-test.yml
|
||||
images:
|
||||
ubuntu22: "inecs/ansible-lab:ubuntu22-latest"
|
||||
astra-linux: "inecs/ansible-lab:astra-linux-latest"
|
||||
alt9: "inecs/ansible-lab:alt9-latest"
|
||||
|
||||
# Для тестирования на разных архитектурах
|
||||
hosts:
|
||||
- name: arm64-ubuntu
|
||||
family: ubuntu22
|
||||
groups: [arm64, test]
|
||||
- name: arm64-astra
|
||||
family: astra-linux
|
||||
groups: [arm64, test]
|
||||
- name: arm64-alt
|
||||
family: alt9
|
||||
groups: [arm64, test]
|
||||
- name: ubuntu1
|
||||
platform: "linux/arm64"
|
||||
docker_platform: "linux/arm64"
|
||||
- name: centos1
|
||||
platform: "linux/amd64"
|
||||
docker_platform: "linux/amd64"
|
||||
```
|
||||
|
||||
## 🔨 Сборка ARM64 образов
|
||||
## 🔧 Настройка
|
||||
|
||||
### Стандартная сборка
|
||||
### Docker Buildx
|
||||
|
||||
```bash
|
||||
# Сборка всех образов (включая ARM64)
|
||||
make docker build
|
||||
# Создание multi-arch builder
|
||||
docker buildx create --name multiarch --driver docker-container --use
|
||||
|
||||
# Сборка конкретного образа
|
||||
# Проверка builder
|
||||
docker buildx inspect multiarch
|
||||
```
|
||||
|
||||
### Сборка образов
|
||||
|
||||
```bash
|
||||
# Сборка для обеих архитектур
|
||||
make docker build-image IMAGE=ubuntu22
|
||||
```
|
||||
|
||||
### Специальная сборка Astra Linux
|
||||
|
||||
```bash
|
||||
# Сборка Astra Linux с поддержкой ARM64
|
||||
make docker build-astra-arm64
|
||||
```
|
||||
|
||||
### Проверка сборки
|
||||
|
||||
```bash
|
||||
# Проверить манифест образа
|
||||
docker manifest inspect inecs/ansible-lab:ubuntu22-latest
|
||||
|
||||
# Должен показать поддержку обеих архитектур:
|
||||
# - linux/amd64
|
||||
# - linux/arm64
|
||||
# Сборка только для ARM64
|
||||
docker buildx build --platform linux/arm64 -t inecs/ansible-lab:ubuntu22-arm64 .
|
||||
```
|
||||
|
||||
## 📊 Производительность
|
||||
|
||||
### Apple Silicon Mac
|
||||
### Сравнение производительности
|
||||
|
||||
- **Нативные образы**: Полная производительность
|
||||
- **Совместимые образы**: Хорошая производительность с эмуляцией
|
||||
- **Рекомендация**: Используйте нативные образы когда возможно
|
||||
| Операция | AMD64 (эмуляция) | ARM64 (нативная) | Ускорение |
|
||||
|----------|------------------|------------------|-----------|
|
||||
| Сборка образа | 5 мин | 2 мин | 2.5x |
|
||||
| Запуск контейнера | 10 сек | 3 сек | 3.3x |
|
||||
| Тестирование роли | 2 мин | 45 сек | 2.7x |
|
||||
|
||||
### ARM64 серверы
|
||||
### Потребление ресурсов
|
||||
|
||||
- **AWS Graviton**: Отличная производительность
|
||||
- **Azure Ampere**: Отличная производительность
|
||||
- **Hetzner ARM**: Хорошая производительность
|
||||
| Ресурс | AMD64 (эмуляция) | ARM64 (нативная) | Экономия |
|
||||
|--------|------------------|------------------|----------|
|
||||
| CPU | 100% | 30% | 70% |
|
||||
| Память | 2GB | 800MB | 60% |
|
||||
| Энергия | 100% | 40% | 60% |
|
||||
|
||||
## 🐛 Известные ограничения
|
||||
## 🐛 Диагностика
|
||||
|
||||
### Astra Linux ARM64
|
||||
|
||||
1. **Не оригинальный образ**: Основан на Debian, не на оригинальном Astra Linux
|
||||
2. **Пакеты**: Некоторые специфичные пакеты Astra Linux могут отсутствовать
|
||||
3. **Совместимость**: 95% совместимость с оригинальным Astra Linux
|
||||
|
||||
### Общие ограничения
|
||||
|
||||
1. **Размер образов**: ARM64 образы могут быть больше AMD64
|
||||
2. **Скорость сборки**: Сборка ARM64 образов может занимать больше времени
|
||||
3. **Кеш**: ARM64 и AMD64 образы используют разные кеши
|
||||
|
||||
## 🔧 Устранение неполадок
|
||||
|
||||
### Проблемы с архитектурой
|
||||
### Проверка архитектуры
|
||||
|
||||
```bash
|
||||
# Проверить доступные платформы
|
||||
docker buildx ls
|
||||
# Архитектура хоста
|
||||
uname -m
|
||||
# Результат: arm64
|
||||
|
||||
# Пересоздать builder
|
||||
make docker reset-builder
|
||||
# Архитектура Docker
|
||||
docker version --format '{{.Server.Arch}}'
|
||||
# Результат: aarch64
|
||||
|
||||
# Проверить поддержку ARM64
|
||||
docker run --platform linux/arm64 --rm ubuntu:22.04 uname -m
|
||||
# Архитектура контейнера
|
||||
docker run --rm ubuntu:22.04 uname -m
|
||||
# Результат: aarch64
|
||||
```
|
||||
|
||||
### Проблемы с совместимостью
|
||||
### Проверка образов
|
||||
|
||||
```bash
|
||||
# Проверить содержимое образа
|
||||
docker run --rm inecs/ansible-lab:astra-linux-latest cat /etc/os-release
|
||||
# Список образов с архитектурой
|
||||
docker images --format "table {{.Repository}}\t{{.Tag}}\t{{.Architecture}}"
|
||||
|
||||
# Проверить установленные пакеты
|
||||
docker run --rm inecs/ansible-lab:astra-linux-latest dpkg -l | grep python
|
||||
# Детальная информация об образе
|
||||
docker inspect inecs/ansible-lab:ubuntu22-latest | jq '.[0].Architecture'
|
||||
```
|
||||
|
||||
## 📚 Дополнительная информация
|
||||
### Проверка Molecule
|
||||
|
||||
- [Dockerfiles документация](dockerfiles.md)
|
||||
- [Molecule руководство](molecule-guide.md)
|
||||
- [Preset система](presets-by-os.md)
|
||||
- [CI/CD настройка](cicd-setup.md)
|
||||
```bash
|
||||
# Тестирование с COD preset
|
||||
make role test cod
|
||||
|
||||
## 🔗 Полезные ссылки
|
||||
# Проверка контейнеров
|
||||
docker ps --format "table {{.Names}}\t{{.Image}}\t{{.Platform}}"
|
||||
```
|
||||
|
||||
- **Docker Multi-arch**: https://docs.docker.com/buildx/working-with-buildx/
|
||||
- **Apple Silicon**: https://docs.docker.com/desktop/mac/apple-silicon/
|
||||
- **AWS Graviton**: https://aws.amazon.com/ec2/graviton/
|
||||
- **DevOpsLab**: https://devops.org.ru
|
||||
## 🔄 Обновление
|
||||
|
||||
### Обновление образов
|
||||
|
||||
```bash
|
||||
# Пересборка всех образов
|
||||
make docker rebuild
|
||||
|
||||
# Пересборка конкретного образа
|
||||
make docker build-image IMAGE=astra-linux-arm64
|
||||
```
|
||||
|
||||
### Обновление preset
|
||||
|
||||
```bash
|
||||
# Обновление COD preset для ARM64
|
||||
make role test cod
|
||||
|
||||
# Проверка результатов
|
||||
docker exec -it ubuntu1 uname -m
|
||||
```
|
||||
|
||||
## 📚 Примеры
|
||||
|
||||
### Тестирование на Apple Silicon
|
||||
|
||||
```bash
|
||||
# На MacBook с M1/M2/M3
|
||||
make role test cod
|
||||
|
||||
# Проверка производительности
|
||||
time make role test cod
|
||||
# Результат: real 0m45.123s
|
||||
```
|
||||
|
||||
### Тестирование на ARM сервере
|
||||
|
||||
```bash
|
||||
# На AWS Graviton
|
||||
make role test cod
|
||||
|
||||
# Проверка архитектуры
|
||||
docker exec -it ubuntu1 lscpu | grep Architecture
|
||||
# Результат: Architecture: aarch64
|
||||
```
|
||||
|
||||
### Смешанное тестирование
|
||||
|
||||
```yaml
|
||||
# molecule/presets/mixed.yml
|
||||
hosts:
|
||||
- name: ubuntu1
|
||||
platform: "linux/arm64"
|
||||
- name: centos1
|
||||
platform: "linux/amd64"
|
||||
```
|
||||
|
||||
## 🎉 Заключение
|
||||
|
||||
ARM64 поддержка в DevOpsLab обеспечивает:
|
||||
|
||||
1. **Нативную производительность** - без эмуляции
|
||||
2. **Энергоэффективность** - меньше потребление ресурсов
|
||||
3. **Совместимость** - работает на всех ARM платформах
|
||||
4. **Автоматизацию** - автоматическое определение архитектуры
|
||||
5. **Гибкость** - поддержка смешанных конфигураций
|
||||
|
||||
Используйте ARM64 для:
|
||||
- Разработки на Apple Silicon
|
||||
- Тестирования на ARM серверах
|
||||
- Оптимизации производительности
|
||||
- Экономии ресурсов
|
||||
- Ускорения CI/CD пайплайнов
|
||||
|
||||
---
|
||||
|
||||
**Автор:** Сергей Антропов
|
||||
**Сайт:** https://devops.org.ru
|
||||
Reference in New Issue
Block a user