Контейнеры systemd-nspawn: различия между версиями
Дым (обсуждение | вклад) Нет описания правки |
Дым (обсуждение | вклад) |
||
Строка 11: | Строка 11: | ||
Как контейнеры запускаются, можно подглядеть в пункте <code>ExecStart</code> сервисного шаблона <strong>/lib/systemd/system/systemd-nspawn@.service</strong>, а именно: | Как контейнеры запускаются, можно подглядеть в пункте <code>ExecStart</code> сервисного шаблона <strong>/lib/systemd/system/systemd-nspawn@.service</strong>, а именно: | ||
# systemd-nspawn --quiet --keep-unit --boot --link-journal=try-guest --network-veth -U --settings=override --machine=%i | # systemd-nspawn --quiet --keep-unit --boot --link-journal=try-guest --network-veth -U --settings=override --machine=%i | ||
С сокращёнными опциями, не загораживая горизонты, та же команда выглядит так: | |||
# systemd-nspawn -q --keep-unit -b -j -n -U --settings=override -M spawn-1 | |||
Войдём для задания пароля без загрузки (-b) и нужной только для юнит-файла <code>--keep-unit</code>: | |||
# systemd-nspawn -q -j -n -U --settings=override -M spawn-1 | # systemd-nspawn -q -j -n -U --settings=override -M spawn-1 | ||
Получив приглашение <code>[root@spawn-1 ~]# </code>, задаём пароль и выходим: | Получив приглашение <code>[root@spawn-1 ~]# </code>, задаём пароль и выходим: | ||
Строка 34: | Строка 36: | ||
Работает. Заходим уже штатным образом: | Работает. Заходим уже штатным образом: | ||
# machinectl login spawn-1 | # machinectl login spawn-1 | ||
А вот тут-то и облом! Если запустить не юнитом, а из командной строки, получаем: | |||
# systemd-nspawn -b -q -j -n -U --settings=override -M alt1 | |||
systemd v243.8-alt2 running in system mode. (+PAM +AUDIT +SELINUX +IMA -APPARMOR +SMACK +SYSVINIT +UTMP +LIBCRYPTSETUP +GCRYPT +GNUTLS +ACL +XZ +LZ4 +SECCOMP +BLKID +ELFUTILS +KMOD +IDN2 -IDN +PCRE2 default-hierarchy=hybrid) | |||
Detected virtualization systemd-nspawn. | |||
Detected architecture x86-64. | |||
Welcome to ALT Starterkit (Hypericum)! | |||
... | |||
alt1 login: root | |||
Password: | |||
Last login: Thu Aug 27 11:55:00 +08 2020 on pts/0 | |||
[root@alt1 ~]# | |||
{{Category navigation|title=Системному администратору|category=Admin|sortkey={{SUBPAGENAME}}}} | {{Category navigation|title=Системному администратору|category=Admin|sortkey={{SUBPAGENAME}}}} | ||
{{Category navigation|title=Виртуализация|category=Виртуализация|sortkey={{SUBPAGENAME}}}} | {{Category navigation|title=Виртуализация|category=Виртуализация|sortkey={{SUBPAGENAME}}}} | ||
[[category:systemd]] | [[category:systemd]] |
Версия от 03:23, 2 октября 2020
Подготовка
Первым делом не обойтись без установки пакета означенной в заголовке системы виртуализации:
# apt-get update && apt-get install systemd-container -y
Вторым — понадобится минимальный образ системы, годный для виртуальных сред контейнерного типа (LXC, Docker и т.п.), взять который можно в репозитории. На момент написания статьи привлекательнее прочих выглядел этот.
Настройка
Допустим, первый контейнер будет называться spawn-1. Тогда распаковать этот образ надо в каталог /var/lib/machines/spawn-1/
, предварительно оный создав.
Дабы впоследствии не мучиться со входом в контейнер с отлупом по паролю, следует задать таковой пользователю root, для чего первый вход произвести в незапущенный контейнер.
Как контейнеры запускаются, можно подглядеть в пункте ExecStart
сервисного шаблона /lib/systemd/system/systemd-nspawn@.service, а именно:
# systemd-nspawn --quiet --keep-unit --boot --link-journal=try-guest --network-veth -U --settings=override --machine=%i
С сокращёнными опциями, не загораживая горизонты, та же команда выглядит так:
# systemd-nspawn -q --keep-unit -b -j -n -U --settings=override -M spawn-1
Войдём для задания пароля без загрузки (-b) и нужной только для юнит-файла --keep-unit
:
# systemd-nspawn -q -j -n -U --settings=override -M spawn-1
Получив приглашение [root@spawn-1 ~]#
, задаём пароль и выходим:
[root@spawn-1 ~]# passwd passwd: updating all authentication tokens for user root. ... Enter new password: Re-type new password: passwd: all authentication tokens updated successfully. [root@spawn-1 ~]# exit logout
Запустим новый контейнер, одновременно включив его запуск при каждой загрузке компьютера:
# systemctl enable --now systemd-nspawn@spawn-1 Created symlink /etc/systemd/system/machines.target.wants/systemd-nspawn@spawn-1.service → /lib/systemd/system/systemd-nspawn@.service.
Проверим, всё ли удалось:
[root@comp ~]# systemctl status systemd-nspawn@spawn-1 ● systemd-nspawn@spawn-1.service - Container spawn-1 Loaded: loaded (/lib/systemd/system/systemd-nspawn@.service; enabled; vendor preset: disabled) Active: active (running) since Thu 2020-10-01 21:38:31 +08; 8s ago Docs: man:systemd-nspawn(1) ...
Работает. Заходим уже штатным образом:
# machinectl login spawn-1
А вот тут-то и облом! Если запустить не юнитом, а из командной строки, получаем:
# systemd-nspawn -b -q -j -n -U --settings=override -M alt1 systemd v243.8-alt2 running in system mode. (+PAM +AUDIT +SELINUX +IMA -APPARMOR +SMACK +SYSVINIT +UTMP +LIBCRYPTSETUP +GCRYPT +GNUTLS +ACL +XZ +LZ4 +SECCOMP +BLKID +ELFUTILS +KMOD +IDN2 -IDN +PCRE2 default-hierarchy=hybrid) Detected virtualization systemd-nspawn. Detected architecture x86-64. Welcome to ALT Starterkit (Hypericum)! ... alt1 login: root Password: Last login: Thu Aug 27 11:55:00 +08 2020 on pts/0 [root@alt1 ~]#