Обновить extentions/README.md

This commit is contained in:
Алексей Костарев 2024-11-18 09:45:17 +03:00
parent e2073d784e
commit f21ca373d5

View File

@ -98,7 +98,7 @@ ghcr.io/siderolabs/nonfree-kmod-nvidia-production:550.90.07-v1.8.2@sha256:86abd0
## Список расширений по группам с методами разворачивания ## Список расширений по группам с методами разворачивания
Описание получения исполнямого кода и файлов конфигурации (в минимальном варианте) находится в файлах pkg.yaml. Описание получения исполняемого кода и файлов конфигурации (в минимальном варианте) находится в файлах pkg.yaml.
Дерево `pkg.yaml` файлов: Дерево `pkg.yaml` файлов:
<pre> <pre>
├── container-runtime ├── container-runtime
@ -220,6 +220,24 @@ ghcr.io/siderolabs/nonfree-kmod-nvidia-production:550.90.07-v1.8.2@sha256:86abd0
└── util-linux └── util-linux
</pre> </pre>
### Структура каталогов расширения
Каждый каталог расширения содержит следующие обязательные файлы:
- `manifest.yaml` - манифест помещающийся в первый слой итогового образа;
- `vars.yaml` - определение переменных, используемых при разворачивании;
- `pkg.yaml` - описание процесса генерации дерева образа, помещаемого вторым слоем итогового образа;
Кроме этого в этот каталог могут помещаться дополнительные файлы:
- `README.md` - описание;
- дополнителньые файлы конфигурации, обычно имеющие суффикс '.part';
- дополнителньые файлы конфигурации форматов `yaml`, `toml`, ...;
- исходный код, используемый при сборка (шаг `build`) расширения;
- бинарный и исполняемый код расширения (шаг `install`);
- ...
### Моды разворачивания расширения
- container-runtime - container-runtime
* crun * crun
@ -241,21 +259,21 @@ ghcr.io/siderolabs/nonfree-kmod-nvidia-production:550.90.07-v1.8.2@sha256:86abd0
* wasmedge * wasmedge
- копирование tar-файла бинарного кода с github.com - копирование tar-файла бинарного кода с github.com
* chelsio(chelsio-drivers_ * chelsio(chelsio-drivers_
- копирование `/lib/modules/` из образа ядра? - копирование `/lib/modules/` из образа ядра
* gasket(gasket-driver) * gasket(gasket-driver)
- копирование `/lib/modules/` из образа? - копирование `/lib/modules/` из образа
* mei * mei
- копирование `/lib/modules/` из образа? - копирование `/lib/modules/` из образа
* mellanox-ofed * mellanox-ofed
- копирование `/lib/modules/` из образа? - копирование `/lib/modules/` из образа
* thunderbolt * thunderbolt
- копирование `/lib/modules/` из образа? - копирование `/lib/modules/` из образа
* uinput * uinput
- копирование `/lib/modules/` из образа? - копирование `/lib/modules/` из образа
* usb-modem(usb-modem-drivers) * usb-modem(usb-modem-drivers)
- копирование `/lib/modules/` из образа? - копирование `/lib/modules/` из образа
* v4l-uvc(v4l-uvc-drivers) * v4l-uvc(v4l-uvc-drivers)
- копирование `/lib/modules/` из образа? - копирование `/lib/modules/` из образа
- examples - examples
* hello-world-service * hello-world-service
@ -263,25 +281,25 @@ ghcr.io/siderolabs/nonfree-kmod-nvidia-production:550.90.07-v1.8.2@sha256:86abd0
- firmware - firmware
* amdgpu-firmware * amdgpu-firmware
- копирование `/lib/firmware/` из образа? - копирование `/lib/firmware/` из образа
* amdgpu-firmware * amdgpu-firmware
- копирование `/lib/firmware/` из образа? - копирование `/lib/firmware/` из образа
* amd-ucode * amd-ucode
- копирование `/lib/firmware/` из образа? - копирование `/lib/firmware/` из образа
* bnx2-bnx2x * bnx2-bnx2x
- копирование `/lib/firmware/` из образа? - копирование `/lib/firmware/` из образа
* chelsio(chelsio-firmware) * chelsio(chelsio-firmware)
- копирование `/lib/firmware/` из образа? - копирование `/lib/firmware/` из образа
* i915-ucode * i915-ucode
- копирование `/lib/firmware/` из образа? - копирование `/lib/firmware/` из образа
* intel-ice-firmware * intel-ice-firmware
- копирование `/lib/firmware/` из образа? - копирование `/lib/firmware/` из образа
* intel-ucode * intel-ucode
- копирование tar-файла бинарного кода с github.com - копирование tar-файла бинарного кода с github.com
* qlogic-firmware * qlogic-firmware
- копирование `/lib/firmware/` из образа? - копирование `/lib/firmware/` из образа
* realtek-firmware * realtek-firmware
- копирование `/lib/firmware/` из образа? - копирование `/lib/firmware/` из образа
- guest-agents - guest-agents
* metal-agent * metal-agent
@ -317,9 +335,9 @@ ghcr.io/siderolabs/nonfree-kmod-nvidia-production:550.90.07-v1.8.2@sha256:86abd0
- storage - storage
* btrfs * btrfs
- копирование `/lib/modules/` из образа? - копирование `/lib/modules/` из образа
* drbd * drbd
- копирование `/lib/modules/` из образа? - копирование `/lib/modules/` из образа
* fuse3 * fuse3
- копирование tar-файла исходного кода с github.com , установка python-модуля, сборка ninja - копирование tar-файла исходного кода с github.com , установка python-модуля, сборка ninja
* iscsi-tools * iscsi-tools
@ -327,7 +345,7 @@ ghcr.io/siderolabs/nonfree-kmod-nvidia-production:550.90.07-v1.8.2@sha256:86abd0
* mdadm * mdadm
- копирование tar-файла исходного кода с www.kernel.org с компиляций кода (make) - копирование tar-файла исходного кода с www.kernel.org с компиляций кода (make)
* zfs * zfs
- копирование `/lib/modules/` из образа? - копирование `/lib/modules/` из образа
- tools - tools
* util-linux(util-linux-tools) * util-linux(util-linux-tools)
@ -335,11 +353,21 @@ ghcr.io/siderolabs/nonfree-kmod-nvidia-production:550.90.07-v1.8.2@sha256:86abd0
## Предложения по разворачиванию расширений (extentions) в ALTLinux ## Предложения по разворачиванию расширений (extentions) в ALTLinux
В ALTlinux предлагается разворачивать ВСЕ расшипения из RPM-пакетов путем установки их в базовый образ `registry.altlinux.org/base/base` с последующим копированием бинарных файлов и файлов конфигурации в соответствующий каталог `/rootfs/` (эту часть можно извлечь из стандартного пакета `pkg.yaml`). Как видно из вышеприведенного списка в `talos` расширения устанавливаются многочисленными способами из многочисленных источников:
В этом случае корректируется только часть `steps.install` файл `pkg.yaml` talos-"пакета" (с возможным удалением предыдущих шагов).
Все отсальные файлы описания talos-пакета остаются неизменными.
Пример развлоачивания пакета `crun`. - копирование бинарного (исполняемого) кода с github.com, ... в исходном виде или в виде tar-архивов с последующим разворачиванием;
- копирование tar-файла исходного кода с github.com, www.kernel.org, src.fedoraproject.org с конфигурацией и компиляций кода;
- копирование бинарного кода (исполняемого) из каталогов docker-образов;
- ...
В ALTlinux предлагается разворачивать ВСЕ расширения из RPM-пакетов путем установки их в базовый образ `registry.altlinux.org/base/base` с последующим копированием бинарных файлов и файлов конфигурации в соответствующий каталог `/rootfs/` (эту часть можно извлечь из стандартного пакета `pkg.yaml`).
В этом случае корректируется только часть `steps.install` файл `pkg.yaml` talos-"пакета" (с возможным удалением предыдущих шагов).
Все остальные файлы описания talos-пакета остаются неизменными.
В определенных случаях при наличи готовых образов возможно копирование бинарного кода (исполняемого) из каталогов docker-образов
регистраторов `registry.altlinux.org`, `gitea.basealt.ru`.
Пример разворачивания пакета `crun`.
- описание стандартного разворачивания - описание стандартного разворачивания
``` ```
@ -394,7 +422,7 @@ variant: scratch
shell: /toolchain/bin/bash shell: /toolchain/bin/bash
dependencies: dependencies:
- stage: base - stage: base
- image: "registry.altlinux.org/alt/alt" - image: registry.altlinux.org/alt/alt
steps: steps:
- prepare: - prepare:
- | - |
@ -421,6 +449,7 @@ finalize:
``` ```
В данном случае из стандартного описания В данном случае из стандартного описания
- в элемент 'dependencies' добавляется зависимость от образа `registry.altlinux.org/alt/alt`
- удаляется шаг `steps.sources`; - удаляется шаг `steps.sources`;
- в шаг `install` добавляется обновление репозитория и установка пакета `crun`; - в шаг `install` добавляется обновление репозитория и установка пакета `crun`;
- во шаге копирования бинарного кода меняется тропа исходного бинарного файла. - во шаге копирования бинарного кода меняется тропа исходного бинарного файла.