Участник:Korotyshev/Подготовка образов для OpenNebula: различия между версиями
Нет описания правки |
Нет описания правки |
||
Строка 4: | Строка 4: | ||
#* (Вариант для опытных пользователей) Cобрать образ вручную на базе rootfs - базовой файловой системы (в комплекте с ней не идет ядро/initrd - их нужно получать отдельно), распространяется в виде архивов (Альт поставляется в нескольких [http://ftp.basealt.ru/pub/distributions/ALTLinux/p10/images/cloud/x86_64/ вариантах] в .tar.xz) либо генерируется самостоятельно через pacstrap/debootstrap/[[hasher|hasher]]/[[LXD#Сборка_с_использованием_официального_rootfs|distrobuilder]]; | #* (Вариант для опытных пользователей) Cобрать образ вручную на базе rootfs - базовой файловой системы (в комплекте с ней не идет ядро/initrd - их нужно получать отдельно), распространяется в виде архивов (Альт поставляется в нескольких [http://ftp.basealt.ru/pub/distributions/ALTLinux/p10/images/cloud/x86_64/ вариантах] в .tar.xz) либо генерируется самостоятельно через pacstrap/debootstrap/[[hasher|hasher]]/[[LXD#Сборка_с_использованием_официального_rootfs|distrobuilder]]; | ||
:: {{ Attention | Даже если формат образа [https://qemu-project.gitlab.io/qemu/system/images.html#disk-image-file-formats поддерживается] QEMU, это не означает, что его можно добавить в хранилище OpenNebula. Поддерживаются форматы RAW, QCOW2 и VMDK. Если образ не поддерживается (например .vhdx), необходимо выполнить конвертацию.}} | :: {{ Attention | Даже если формат образа [https://qemu-project.gitlab.io/qemu/system/images.html#disk-image-file-formats поддерживается] QEMU, это не означает, что его можно добавить в хранилище OpenNebula. Поддерживаются форматы RAW, QCOW2 и VMDK. Если образ не поддерживается (например .vhdx), необходимо выполнить конвертацию.}} | ||
Для создания образа будут использоваться qemu-kvm и qemu-img (пакеты [https://packages.altlinux.org/ru/sisyphus/binary/qemu-img/ qemu-img] [https://packages.altlinux.org/ru/sisyphus/binary/qemu-kvm/ qemu-kvm] [https://packages.altlinux.org/ru/sisyphus/binary/qemu-ui-gtk/ qemu-ui-gtk] [https://packages.altlinux.org/ru/sisyphus/binary/qemu-device-display-virtio-gpu/ qemu-device-display-virtio-gpu]) | |||
== Кастомизация готового образа == | == Кастомизация готового образа == | ||
{{note|Все действия будут проводиться в Live-окружении [https://www.altlinux.org/Rescue Alt Regular Rescue]}} | {{note|Все действия будут проводиться в Live-окружении [https://www.altlinux.org/Rescue Alt Regular Rescue]}} | ||
Строка 29: | Строка 29: | ||
umount -R /mnt | umount -R /mnt | ||
poweroff</syntaxhighlight> | poweroff</syntaxhighlight> | ||
== Установка системы с нуля == | |||
== Установка средств контекстуализации == |
Версия от 18:11, 7 февраля 2024
OpenNebula хоть и позволяет использовать ВМ с полной инсталляцией через livecd на каждом инстансе, однако всё же рассчитана на разворачивание уже установленной ОС, которая в зависимости от настроек будет загружать публичные ключи SSH, настраивать пароли локальных учетных записей, а также выполнять пользовательские скрипты и выставлять IP-адреса. Всё это возможно благодаря службе контекстуализации, которая встраивается в систему при создания образа. Подготовить образ можно двумя способами:
- Загрузить готовый cloud-образ и настроить под свои нужды; Примечание: Для OpenNebula выпускаются голые образы Альт с уже встроенной службой opennebula-context, а также с cloud-init (альтернативный инструмент инициализации системы, подробнее на отдельной странице).
- Создать голый образ диска, установить систему с livecd вместе с желаемыми пакетами, а затем подготовить его для OpenNebula;
- (Вариант для опытных пользователей) Cобрать образ вручную на базе rootfs - базовой файловой системы (в комплекте с ней не идет ядро/initrd - их нужно получать отдельно), распространяется в виде архивов (Альт поставляется в нескольких вариантах в .tar.xz) либо генерируется самостоятельно через pacstrap/debootstrap/hasher/distrobuilder;
- Внимание! Даже если формат образа поддерживается QEMU, это не означает, что его можно добавить в хранилище OpenNebula. Поддерживаются форматы RAW, QCOW2 и VMDK. Если образ не поддерживается (например .vhdx), необходимо выполнить конвертацию.
Для создания образа будут использоваться qemu-kvm и qemu-img (пакеты qemu-img qemu-kvm qemu-ui-gtk qemu-device-display-virtio-gpu)
Кастомизация готового образа
- Загружаем облачный образ для opennebula
wget http://ftp.basealt.ru/pub/distributions/ALTLinux/images/Sisyphus/cloud/x86_64/alt-sisyphus-opennebula-x86_64.qcow2
- Увеличиваем максимальный размер диска на 1G
qemu-img resize alt-sisyphus-opennebula-x86_64.qcow2 +1G
- Запускаем qemu/kvm с нужными параметрами
qemu-system-x86_64 -accel kvm -machine q35 -m 3072M -drive format=qcow2,file=./alt-sisyphus-opennebula-x86_64.qcow2 -cdrom regular-rescue-latest-x86_64.iso -vga virtio -boot d
- Расширяем раздел
parted /dev/sda resizepart 1 100%
- Расширяем ext4 на увеличенном разделе
resize2fs /dev/sda1
- Монтируем раздел вместе с proc и dev
mount /dev/sda1 /mnt mount --bind /proc /mnt/proc mount --bind /dev /mnt/dev mount --bind /etc/resolv.conf /mnt/etc/resolv.conf
- Делаем chroot до точки монтирования
chroot /mnt /bin/sh
- Примечание: Если необходимо подключение к сети внутри окружения, перед входом в chroot необходима настройка интерфейса.
На данном этапе доступна консоль, в которой можно сделать нужные изменения, например:
Обновить систему, установить утилиты nano,tmux
apt-get update && apt-get -y install nano tmux && apt-get clean
После завершения настройки выходим из командной оболочки, выполняем размонтирование и завершаем работу
exit
umount -R /mnt
poweroff