systemd-boot (Русский)
systemd-boot, ранее известный как gummiboot - это простой UEFI менеджер загрузки, который исполняет настроенные EFI образы. Запись по умолчанию выбирается с помощью настроенного шаблона (glob) или меню на экране. Включен в пакет systemd, который устанавливается на системе Arch по умолчанию.
Прост в настройке, но способен только на запуск исполняемых EFI файлов, таких как ядро Linux EFISTUB, UEFI Shell, GRUB, Windows Boot Manager.
Установка
Загрузка в режиме EFI
- Убедитесь, что вы загружены в режиме UEFI.
- Проверьте доступны ли EFI переменные.
- Корректно примонтируйте Системный Раздел EFI (ESP). В этой статье
esp
используется для обозначения точки монтирования.Примечание: systemd-boot EFI не может загружать бинарные файлы из других разделов. По этой причине, рекомендуется монтировать ваш ESP в/boot
. В случае, если вы хотите разделить/boot
с ESP, обратитесь к #Обновлениe для большей информации. - Если ESP не примонтирован к
/boot
, копируйте ваше ядро и initramfs в ESP. - Введите следующую команду для установки systemd-boot:
# bootctl --path=''esp'' install
Она скопирует двоичный файл systemd-boot на Системный Раздел EFI ( и - оба идентичны на x86-64 системах) и добавит systemd-boot как EFI приложение по умолчанию (загрузочная запись по умолчанию), загружаемое с помощью EFI Boot Manager. - Наконец, для правильного функционирования вы должны настроить загрузчик.
Загрузка в режиме BIOS
Вы с таким же успехом можете установить systemd-boot, если загружаетесь в режиме BIOS. Тем не менее, от вас всё равно требуется сообщить прошивке запускать EFI файл systemd-boot при загрузке:
- у вас есть работающий EFI shell где-нибудь.
- ваш интерфейс прошивки предоставляет вам соответствующий способ настройки EFI файла, который будет загружен во время загрузки.
Если вы имеете такую возможность, процесс установки будет проще: перейдите в ваш EFI shell или интерфейс настройки вашей прошивки и измените EFI файл по умолчанию вашей машины на ( или если у вас 32 битная системная прошивка).
Обновлениe
В отличие от предыдущего отдельного пакета gummiboot, который автоматически обновляется с помощью скрипта, обновления systemd-boot теперь должны производиться пользователем вручную. Однако, эта процедура может быть автоматизирована с использованием pacman hooks.
Вручную
systemd-boot (bootctl(1)) предполагает, что ваш Системный Раздел EFI примонтирован в /boot
.
# bootctl update
Если ESP не примонтирован в /boot
, опцией можно явно указать точку монтирования, например:
# bootctl --path=esp update
Автоматически
AUR (Русский) пакет предоставляет хук Pacman для автоматизации процесса обновления. Установка этого пакета добавит hook, который будет выполняться при каждом обновлении пакета systemd.
В качестве альтернативы, вы можете разместить следующий pacman hook в каталоге /etc/pacman.d/hooks/:
Настройка
Базовая настройка
Базовая конфигурация хранится в файле . Полный список опций описан в loader.conf(5) § OPTIONS. Некоторые важные опции:
default
– выбираемая по умолчанию запись; можно использовать подстановку, например
- – задержка меню в секундах. Если таймаут не задан, то меню будет отображаться, только если удерживать клавишу (другие клавиши тоже могут работать) при загрузке.
- — разрешение экрана в консоли. Значение (по умолчанию) оставляет то разрешение, которое было выбрано прошивкой. Значение выбирает максимальный доступный режим.
- - следует ли включить редактор параметров ядра. (по умолчанию) - включить, - отключить; Поскольку пользователь может добавить
init=/bin/bash
для обхода пароля администратора и получить полный доступ, настоятельно рекомендуется установить эту опцию в .
Пример:
- Используйте пробелы; systemd-boot не поддерживает символы табуляции.
- Опции
default
иtimeout
могут быть изменены в самом меню загрузки, эти изменения будут храниться как переменные EFILoaderEntryDefault
иLoaderConfigTimeout
, переопределяя настройки из файла конфигурации. - Можно использовать
bootctl set-default ""
для сброса переменной EFI, переопределяющей опциюdefault
. - Пример базового конфигурационного файла расположен как
/usr/share/systemd/bootctl/loader.conf
.
Добавление загрузочных записей
bootctl ищет элементы для загрузочного меню в – каждый найденный файл должен содержать точно одну загрузочную запись. Возможными опциями являются:
- – название операционной системы. Обязательная.
- – версия ядра, отображаемая только если существуют несколько записей с одинаковым названием. Не обязательная.
- – идентификатор машины из , отображаемый только если существуют несколько записей с одинаковым названием и одинаковой версией. Не обязательная.
- – EFI программа для запуска, относительно вашего ESP (
$esp
); например, . Либо это, либо (смотрите ниже) является обязательным.
- – опции командной строки для передачи EFI приложению. Не обязательная, но вам нужно будет передать как минимум и
root=dev
если загружаете Linux.
Для Linux вы можете задать и ; это автоматически преобразуется в и options initrd=path
– этот синтаксис поддерживается только для удобства и не имеет различий по функциональности.
Установки со стандартной корневой директорией
Вот пример записи для корневого раздела без LVM или LUKS:
Пожалуйста, обратите внимание, что в вышеприведённом примере / идентифицируют GPT раздел, а это не то же самое, что /, которые идентифицируют файловую систему. Использование / бывает полезным, потому что они инвариантны (то есть неизменяемы), если вы переформатируете раздел в другую файловую систему или если по какой-то причине изменятся обозначения /dev/sd*. Также оно может быть полезно, если у вас нет файловой системы на разделе (или вы используете LUKS, который не поддерживает метки ).
Установки с LVM корневой директорией
Следующий пример для корневой директории с использованием логического менеджера разделов:
''esp''/loader/entries/arch-lvm.conf
title Arch Linux (LVM) linux /vmlinuz-linux initrd /initramfs-linux.img options root=/dev/mapper/<VolumeGroup-LogicalVolume> rw
Замените на актуальные названия VG и LV (например, ). Кроме того, вместо них можно использовать UUID:
.... options root=UUID=<UUID identifier> rw
Обратите внимание, что root=UUID=
используется вместо , который используется для корневых разделов без LVM или LUKS.
Установки с зашифрованной корневой директорией
Ниже приведен пример конфигурационного файла для зашифрованного корневого раздела (DM-Crypt / LUKS) с использованием mkinitcpio (Русский) hook:
В этом примере используется UUID; если хотите, можете заменить UUID на . Вы можете также заменить путь на регулярный UUID. - название, которое вы желаете использовать. Смотрите Dm-crypt/System configuration#Boot loader.
Если вы используете LVM, ваша опция cryptdevice будет выглядеть следующим образом:
Вы также можете добавить другие EFI приложения, такие как \EFI\arch\grub.efi
.
Установка корневого подраздела btrfs
При загрузке с подраздела Btrfs (Русский) в роли корневого, добавьте к строке . В примере ниже, корневой раздел монтируется как btrfs подраздел с именем 'ROOT' (например, mount -o subvol=ROOT /dev/sdxY /mnt
):
Если это невозможно сделать, то это приведет к ошибке:
Установки с ZFS корневой директорией
В случае загрузки из ZFS dataset, добавьте к строке . Здесь в корневом dataset установлено значение 'zroot/ROOT/default':
When booting off of a ZFS dataset ensure that it has had the property set with .
EFI Shells или другие EFI приложения
В случае, если вы установили EFI Shells или другие EFI приложения в ESP, вы можете использовать следующие фрагменты:
''esp''/loader/entries/uefi-shell-v1-x86_64.conf
title UEFI Shell x86_64 v1 efi /EFI/shellx64_v1.efi
Поддержка гибернации
Пожалуйста, прочтите статью Power management/Suspend and hibernate (Русский).
Редактор параметров ядра с защитой паролем
В качестве альтернативы можете установить который поддерживает опцию базовой конфигурации. Используйте для генерации значения для этой опции.
Установка systemd-boot-password следующей командой:
# sbpctl install ''esp''
С включенным редактором будет запрошен ваш пароль, перед тем как вы сможете редактировать параметры ядра.
Клавиши в загрузочном меню
В меню используются следующие клавиши:
- - выбор записи
- - загрузить выбранную запись
- - выбрать загрузочную запись по умолчанию (хранится в энергонезависимой EFI переменной)
- - уменьшить таймаут (хранится в энергонезависимой EFI переменной)
- - увеличить таймаут (хранится в энергонезависимой EFI переменной)
e
- редактировать командную строку ядра. Не имеет эффекта, если опция конфигурации установлена в .- - показать версию gummiboot и UEFI
- - выйти
- - отобразить текущую конфигурацию
- - помощь
А эти клавиши, нажатые в меню в процессе загрузки, сразу загрузят определённую запись:
- - Linux
- - Windows
a
- OS X- - EFI Shell
- - порядковый номер записи
Решение проблем
Создание записи вручную с помощью efibootmgr
Если команда bootctl install
не сработала, вы можете создать загрузочную EFI запись самостоятельно с помощью утилиты :
# efibootmgr -c -d /dev/sdX -p Y -l /EFI/systemd/systemd-bootx64.efi -L "Linux Boot Manager"
где - это ваш EFISYS раздел.
Меню не отображается после обновления Windows
Обратитесь к разделу соответствующей статьи: Unified Extensible Firmware Interface#Windows changes boot order.