mkinitcpio (Русский)
mkinitcpio — это bash-скрипт, используемый для создания начального загрузочного диска системы. Из mkinitcpio(8) man page:
- The initial ramdisk is in essence a very small environment (early userspace) which loads various kernel modules and sets up necessary things before handing over control to init. This makes it possible to have, for example, encrypted root file systems and root file systems on a software RAID array. mkinitcpio allows for easy extension with custom hooks, has autodetection at runtime, and many other features.
Традиционно ядро отвечает за обнаружение всего оборудования и выполняет задачи на ранних этапах процесса загрузки до монтирования корневой файловой системы. Однако по мере развития технологий эти задачи становятся всё более сложными.
В настоящее время корневая файловая система может быть на широком диапазоне аппаратных средств от SCSI до SATA и USB дисков, управляемых различными контроллерами от разных производителей. Кроме того корневая файловая система может быть зашифрована или сжата, находиться в RAID массиве или группе логических томов. Простой способ справиться с этой сложностью является передача управления в пользовательском пространстве: начальный загрузочный диск. Смотрите также: /dev/brain0 » Blog Archive » Early Userspace in Arch Linux.
mkinitcpio создан разработчиками Arch Linux и вкладами сообщества. Смотрите public Git repository.
Установка
Установите пакет mkinitcpio, который является зависимостью пакета , поэтому большинство пользователей уже установили его.
Продвинутые пользователи могут захотеть установить последнюю версию mkinitcpio из Git с пакетом .
Создание загрузочного образа
Автоматическая генерация
Каждый раз, когда ядро устанавливается или обновляется, pacman-хук генерирует файл предустановки (.preset) и сохраняет его в /etc/mkinitcpio.d/
. Например, для официального пакета создаётся файл . Предустановка — это просто список информации, необходимой для создания начальных образов RAM-диска, вместо того, чтобы вручную указывать различные параметры и расположение выходных файлов.
По умолчанию mkinitcpio генерирует два образа после установки или обновления ядра:
- default, создаваемый в соответствии с директивами, указанными в настройках, и
- fallback, который создается с точно таким же конфигурационным файлом за исключением хука autodetect, что позволяет включить в него все модули.
Ручная генерация
Чтобы запустить скрипт вручную, обратитесь к mkinitcpio(8) для чтения инструкций. В частности, чтобы (повторно) сгенерировать предустановку, предоставленную пакетом ядра, используйте параметр / с именем нужной предустановки. Для стандартного ядра Arch Linux, :
# mkinitcpio -p linux
Чтобы (повторно) сгенерировать все существующие предустановки, используйте параметр /. Обычно это используется для регенерации всех образов initramfs после изменения глобальных настроек:
# mkinitcpio -P
Параметр (сокращение от preset) указывает на использование preset файла из /etc/mkinitcpio.d
(т.е. для ). preset файл определяет параметры сборки initramfs образа вместо указания файла конфигурации и выходной файл каждый раз.
Можно создать любое количество initramfs с различными конфигурациями. Необходимый initramfs должен быть прописан в конфигурационном файле загрузчика.
Варианты создания initcpio
Пользователи могут вручную создать образ с помощью альтернативного конфигурационного файла. Например, следующее будет генерировать initramfs образ в соответствии с /etc/mkinitcpio-custom.conf
и сохранит его в .
# mkinitcpio --config /etc/mkinitcpio-custom.conf --generate /boot/initramfs-custom.img
Если необходимо создать образ с ядром отличным от загруженного, добавьте параметр с версией ядра. Доступные версии ядер можно посмотреть в , синтаксис соответствует выводу для каждого ядра.
# mkinitcpio --generate /boot/initramfs-custom2.img --kernel 5.7.12-arch1-1
Unified kernel images
С версии 31 mkinitpcio также может генерировать unified kernel image.
Настройка
- основной конфигурационный файл mkinitcpio. Кроме того, в каталоге /etc/mkinitcpio.d
располагаются preset файлы (e.g. ).
Можно изменять шесть переменных в конфигурационном файле:
- Модули ядра, которые будут загружены до выполнения хуков.
- Дополнительные исполняемые файлы, которые необходимо включить в initramfs.
- Дополнительные файлы, которые необходимо включить в initramfs.
- Hooks - скрипты, выполняемые в initramfs.
COMPRESSION
- Тип используемого сжатия initramfs.
- Дополнительные опции архиваторов. Использование этого параметра не рекомендуется. mkinitcpio будет обрабатывать особые требования к архиваторам (например
--check=crc32
для xz), что может привести к невозможности запуска системы.
MODULES
Указывает какие модули ядра должны быть загружены прежде чем что-либо будет сделано.
Для модулей с суффиксом не будет выводиться ошибка, если они не будут найдены. Это может быть полезно для пользовательских ядер.
BINARIES и FILES
Указывают какие файлы необходимо добавить в initramfs. и будут добавлены до запуска хуков и использоваться для переопределения файлов использаемых хуками. - бинарные файлы из , необходимые для работы библиотеки будут автоматически добавлены. добавляет файлы как есть. Например:
FILES=(/etc/modprobe.d/modprobe.conf)
BINARIES=(kexec)
И , и являются bash-массивами, в них можно добавить несколько файлов с пробелом в качестве разделителя.
HOOKS
Параметр наиболее важный в файле настроек. Хуки - это небольшие скрипты, которые описывают что будет добавлено к образу, а также дополнительные действия, выполняемые при загрузке системы. Хуки указываются по имени и выполняются по порядку.
Значение по умолчанию для должно быть достаточным для большинства простых установок с одним диском. Для корневых устройств, которые являются многоуровневыми или многоблочными устройствами, такими как LVM, mdadm или dm-crypt, см. cоответствующие страницы вики для дальнейшей необходимой конфигурации.
Build hooks
Build hooks - хуки сборки. Располагаются в ; пользовательские хуки можно добавить в . Эти файлы используются mkinitcpio во время сборки initramfs. Должны содержать две функции: и help
. Функция перечисляет модули, файлы, исполняемые файлы, которые добавляются в образ. Функция help
содержит описание действий хука.
Для получения списка всех доступных хуков:
$ mkinitcpio -L
Используйте опцию / для вывода информации о конкретном хуке:
$ mkinitcpio -H udev
Runtime hooks
Runtime hooks - хуки времени выполнения. Располагаются в , пользовательские хуки могут быть помещены в . Для любого runtime-хука всегда должен быть build-хук с тем же именем, в котором имеется вызов , указывающий на добавление runtime-хука в образ. Эти файлы обрабатываются командным интерпретатором ash из busybox во время early userspace. Они запускаются по порядку записи в за исключением хуков очистки. Runtime хуки могут содержать несколько функций:
run_earlyhook
: Функции с таким именем будут запускаться один раз после установки API файловых систем и обработки командной строки ядра. Как правило, здесь запускаются дополнительные демоны, такие как udev, необходимые для раннего процесса загрузки.
: Функции с таким именем запускаются вскоре после ранних хуков. Это наиболее распространенная точка хуков, и здесь должны выполняться операции, такие как сборка многоуровневых блочных устройств.
: Функции c этим именем запускаются после того, как была примонтирована корневая файловая система. Это следует использовать, умеренно, для дальнейшей настройки корневой ФС или для монтирования других файловых систем, таких как .
run_cleanuphook
: Функции с этим именем запускаются как можно позже, и в порядке обратном, порядку их перечисления в файла конфигурации. Эти хуки должны использоваться для любой очистки в последнюю минуту, например, для закрытия всех демонов, запущенных ранними хуками.
Доступные хуки
Таблица стандартных хуков и как они влияют на создание и выполнение образа. Обратите внимание, что эта таблица не является полной, так как пакеты могут предоставлять свои хуки.
busybox init | systemd init | Build hook | Runtime hook |
---|---|---|---|
colspan="2" | Устанавливает все начальные каталоги, базовые утилиты и библиотеки. Всегда ставьте этот хук первым, за исключением случаев, когда вы действительно знаете, что делаете, если не используется хук systemd.
Предоставляет busybox recovery shell при использовании совместно с хуком systemd. |
||
systemd | Добавляет udev, udevadm и небольшое подмножество правил udev в образ. | Udev автоматически создает файл устройства для корня и загружает необходимые модули для его работы. Рекомендуется использовать. | |
Добавляет поддержку отделного раздела. Подробнее: #/usr на отдельном разделе | Монтирует раздел после монтирования корневой файловой системы. | ||
Необходим для работы спящего режима (suspend to disk). Смотрите Ждущий и спящий режимы. | |||
-- | Sets the required modules to enable Btrfs for using multiple devices with Btrfs. This hook is not required for using Btrfs on a single device. | Runs to assemble a multi-device Btrfs root file system when udev hook or systemd hook is not present. The package is required for this hook. | |
colspan="2" | Уменьшает размер initramfs, пытаясь определить, какие модули вам нужны, сканируя sysfs. Проверьте список модулей, которые он добавил. Он должен запускаться раньше других подсистем. Все обработчики, выполняемые до него, будут включать все модули. | ||
colspan="2" | Добавляет конфигурационные файлы modprobe из и | ||
colspan="2" | Добавляет все модули блочных устройств, ранее предоставляемые другими хуками (fw, mmc, pata, sata, scsi, usb, virtio). | ||
не реализован | Добавляет поддержку сети. Установите для использования этого хука. Подробнее: #При использовании net | Требуется для корневой файловой системы через NFS. | |
? | Поддержка корневой файловой системы на fakeRAID массивах. Необходимо установить пакет . Обратите внимание, что необходимо использовать с хуком mdadm_udev с fakeRAID если ваш контроллер поддерживает это. Подробнее: #При использовании RAID | Находит и монтирует fakeRAID блочные устройства, используя . | |
colspan="2" | Обеспечивает поддержку для сборки RAID массивов с помощью udev. Необходимо установить пакет . Если вы используете этот хук с массивом FakeRAID, рекомендуется включить в секции . Подробнее: #При использовании RAID | ||
colspan="2" | Добавляет модули, необходимые для работы клавиатур. Используйте этот хук, если необходимо использовать USB-клавиатуру на ранней стадии загрузки (для ввода пароля от заширфованных данных или для работы в командной оболочке). В качестве побочного эффекта также могут быть добавлены модули для некоторых устройств ввода без клавиатуры, но на это не следует полагаться. Заменяет старый хук usbinput.
Примечание: Для систем, которые загружаются с различными конфигурациями оборудования (например, ноутбуки с внешней клавиатурой или внутренней клавиатурой или headless-системы), этот хук необходимо поместить перед autodetect, чтобы иметь возможность использовать клавиатуру во время загрузки, например, чтобы разблокировать зашифрованное устройство при использовании хука encrypt . |
||
rowspan="2" | Добавляет в initramfs раскладки, указанные в . При использовании шифрования системы добавляйте его перед хуком . | Загружает раскладки, указанные в . | |
consolefont | Добавляет в initramfs консольный шрифт, указанный в . | Загружает шрифт, указанный в . | |
Добавлет модуль ядра и . Требуется пакет cryptsetup. | Определяет и подключает зашифрованый корневой раздел. Смотрите #Настройка во время выполнения для дальнейшей настройки.
Для sd-encrypt смотрите dm-crypt/System configuration#Using systemd-cryptsetup-generator. | ||
colspan="2" | Добавляет поддержку . Требует установленного пакета . Необходим, если корневая файловая система на LVM. | ||
colspan="2" | Добавляет исполняемый файл fsck и необходимые обработчики файловых систем для проверки корневой файловой системы (и , если он на отдельном разделе) перед монтированием. Если стоит после хука autodetect, то будут добавлены только обработчики для вашей корневой файловой системы. Использование этого хука настоятельно рекомендуется и обязательно с отдельным разделом. При включении этого хука крайне рекомендуется также включить все необходимые модули для обеспечения работы вашей клавиатуры в early userspace. Использование этого хука требует, чтобы rw передавался в командной строке ядра (обсуждение). Смотрите fsck (Русский)#Проверка при загрузке для подробностей. | ||
colspan="2" | Включает в образ модули необходимых файловых систем. Этот хук обязателен, если Вы не указываете модули файловых систем в MODULES. | ||
COMPRESSION
Ядро поддерживает несколько форматов для сжатия initramfs - gzip, , lzma, , lzo, и . По умолчанию mkinitcpio использует zstd; имейте в виду, что сжатие zstd работает в многопоточном режиме (с опцией , которая запускает столько же потоков, сколько ядер в процессоре).
Стандартный имеет различные закомментированные варианты COMPRESSION
. Раскомментируйте один, чтобы выбрать необходимый формат сжатия. Чтобы создать несжатый образ, укажите в конфигурации или используйте в командной строке.
Убедитесь, что для метода, который вы хотите использовать, установлена правильная утилита сжатия файлов.
COMPRESSION_OPTIONS
Это дополнительные флаги, переданные программе, указанной COMPRESSION
, например:
COMPRESSION_OPTIONS=(-9)
Настройка во время выполнения
Настройки среды выполнения могут быть переданы в и некоторые хуки через параметры ядра, которые обычно задаются в загрузчике. Приведённые ниже параметры могут быть добавлены в командную строку ядра для изменения поведения по умолчанию. Подробности смотрите в статьях Параметры ядра и Процесс загрузки Arch.
init from base hook
- Это самый важный параметр, указываемый в командной строке ядра, поскольку он определяет, какое устройство будет смонтировано как корневая ФС. mkinitcpio поддерживает большой набор форматов, например: Примечание: Следующие параметры загрузки изменяют поведение
init
по умолчанию в среде initramfs. Подробнее смотрите/usr/lib/initcpio/init
. Они не будут работать при использовании хукаsystemd
, так как он заменитinit
из хукаbase
.
- Если указан или , приостановит процесс загрузки (после загрузки хуков, но перед монтированием корневой ФС) и запустит интерактивную оболочку, которую можно использовать для устранения неполадок. Эту оболочку можно запустить после монтирования корневой ФС, указав . После выхода из оболочки продолжится обычная загрузка.
- Отключает runtime-хуки, перечисленные через запятую . Например:
disablehooks=resume
- Изменяет порядок загрузки модулей, загружая указанные здесь модули раньше остальных: . (Это может использоваться, например, для обеспечения правильного порядка нескольких сетевых интерфейсов.)
Смотрите Устранение часто встречающихся неполадок#Проблемы загрузки и mkinitcpio(8) для более подробной информации.
При использовании RAID
Смотрите RAID#Configure mkinitcpio.
При использовании net
Требуемые пакеты
Хук требует пакет .
Параметры ядра
Полную и актуальную информацию можно найти в официальной документации ядра.
ip=
Этот параметр сообщает ядру, как настраивать IP-адреса устройств и таблицу маршрутизации. Может принимать до девяти аргументов, разделённых двоеточиями:
ip=<client-ip>:<server-ip>:<gw-ip>:<netmask>:<hostname>:<device>:<autoconf>:<dns0-ip>:<dns1-ip>:<ntp0-ip>
.
Если этот параметр не указан, все поля считаются пустыми и используются значения по умолчанию, описанные в документации ядра. В целом это подразумевает, что ядро пытается настроить всё с помощью автоконфигурации.
Можно указать в одиночку как значение параметра (без всех двоеточий перед ним). Значение или отключает автоконфигурацию. Чаще всего используется ip=dhcp
.
Разъяснение параметров:
<client-ip> IP адрес клиента. Если пустой, то автоматически назначается протоколом RARP/BOOTP/DHCP. Какой протокол используется зависит от параметра <autoconf>. Если его значение не пустое, то autocnf работает корректно. <server-ip> IP адрес NFS сервера. Если используется RARP для определения адреса клиента и этот параметр не пуст, то принимаются ответы только от указанного сервера. Для использования разных RARP и NFS серверов, укажите ваш RARP сервер здесь (или оставьте пустым), и укажите ваш NFS сервер в параметре `nfsroot' (см. выше). Если тут пусто, будет использован сервер, ответивший на RARP/BOOTP/DHCP запрос. <gw-ip> IP адрес шлюза если сервер в другой подсети. Если тут пусто, предполагается, что сервер находится в одной подсети, если значение не получено по BOOTP/DHCP. <netmask> Маска подсети для локального интерфейса. Если тут пусто, используется маска по умолчанию в зависимости от класса IP, если конечно не переопределена значением из BOOTP/DHCP ответа. <hostname> Имя машины клиента. Если пусто, используется IP адрес в виде ASCII строки, или значение полученное по BOOTP/DHCP. <device> Имя сетевого устройства. Если тут пусто, все устройства будут использованы для RARP/BOOTP/DHCP запросов, и все настройки будут получены из первого пришедшего ответа. Если вы имеете только одно сетевое устройство, можно спокойно оставить поле пустым. <autoconf> Какой метод использовать для автонастройки: 'rarp', 'bootp', или 'dhcp'. Если значение 'both', 'all' или пусто, все протоколы будут использованы. 'off', 'static' или 'none' означают запрет автонастройки. <dns0-ip> IP-адрес основного DNS-сервера. Определяется автоматически при включенном autoconf. Значение доступно в /proc/net/pnp с префиксом "nameserver ". <dns1-ip> IP-адрес запасного DNS-сервера, аналогично <dns0-ip>. <ntp0-ip> IP-адрес NTP-сервера. Определяется автоматически при включенном autoconf. Значение доступно в /proc/net/ipconfig/ntp_servers, ядром не используется.
Полное объяснение параметров можно почитать в документации ядра (на английском).
Примеры:
ip=127.0.0.1:::::lo:none --> Разрешить lo интерфейс. ip=192.168.1.1:::::eth2:none --> Статический eth2 интерфейс. ip=:::::eth0:dhcp --> Разрешить dhcp протокол для настройки интерфейса eth0.
BOOTIF=
Если у вас несколько сетевых карт, в этом параметре можно указать MAC-адрес интерфейса, с которого вы загружаетесь. Это часто бывает полезно, так как нумерация интерфейсов может измениться, или в сочетании с опцией pxelinux IPAPPEND 2 или IPAPPEND 3. Если не указан, будет использоваться .
Пример
BOOTIF=01-A1-B2-C3-D4-E5-F6 # Обратите внимание на ведущий "01-" и верхний регистр.
nfsroot=
Если параметр 'nfsroot' НЕ передан, будет использовано значение по умолчанию "/tftpboot/%s".
nfsroot=[<server-ip>:]<root-dir>[,<nfs-options>]
Описание параметров:
<server-ip> IP адрес NFS сервера. Если параметр отсутствует адрес по умолчанию определяется по переменной `ip' (см. ниже). Одно из применений этого параметра - использование разных серверов для RARP и NFS. Обычно можете оставить этот параметр пустым. <root-dir> Путь к директории, которая будет корневой на клиенте. Если тут написано "%s", то оно будет заменено на ASCII представление IP клиента. <nfs-options> Стандартные опции NFS. Все опции разделены запятыми. Если опция отсутствует будут использованы следующие значения по умолчанию: port = как скажет portmap демон на сервере rsize = 1024 wsize = 1024 timeo = 7 retrans = 3 acregmin = 3 acregmax = 60 acdirmin = 30 acdirmax = 60 flags = hard, nointr, noposix, cto, ac
Полное описание параметров можно почитать в (на английском).
При использовании lvm
Если ваш корень находится на LVM, смотрите Install Arch Linux on LVM#Adding mkinitcpio hooks.
При зашифрованном корневом разделе
Если у вас зашифрованный корень, смотрите dm-crypt/System configuration#mkinitcpio для информации о том, какие хуки нужно добавлять.
/usr на отдельном разделе
Если у вас на отдельном разделе, вы должны соблюдать следующие требования:
- Добавьте хук , а в файле укажите для значение
2
, чтобы запускалась проверка этого раздела при загрузке системы. Без этого хука проверяться не будет. - Если не используется хук systemd, добавьте хук , который будет монтировать раздел после монтирования корневой ФС.
Решение проблем
Распаковка образа
Если вам интересно посмотреть, что находится внутри образа initramfs, вы можете распаковать его.
Образ initramfs является архивом SVR4 CPIO, созданным с помощью команд и и опционально сжатым с форматом сжатия, понятным ядру. Подробнее о сжатии смотрите в разделе #COMPRESSION.
mkinitcpio включает в себя инструмент lsinitcpio(1), позволяющий посмотреть и/или извлечь содержимое образов initramfs.
Просмотр списка файлов в образе:
# lsinitcpio /boot/initramfs-linux.img
Извлечение всех файлов в текущий каталог:
# lsinitcpio -x /boot/initramfs-linux.img
Более удобный обзор самых важных частей образа:
# lsinitcpio -a /boot/initramfs-linux.img
Изменение и упаковка образа
После распаковки архива описанным выше способом вы можете изменить файлы и упаковать всё обратно. Вызовите функцию из скрипта с параметрами
build_image выходной-файл сжатие
Это можно сделать путём создания нового скрипта с содержимым функции и его вызова с описанными выше параметрами. Он упакует содержимое текущего каталога в .
"/dev must be mounted", хотя он и так примонтирован
mkinitcpio считает примонтированным при наличии . Если всё выглядит хорошо, его можно «создать» вручную:
# ln -s /proc/self/fd /dev/
(Очевидно, /proc
тоже должен быть примонтирован. mkinitcpio всё равно это требует и тоже это проверяет.)
Possibly missing firmware for module XXXX
В процессе сборки initramfs после обновления ядра вы можете заметить подобные предупреждения:
==> WARNING: Possibly missing firmware for module: wd719x ==> WARNING: Possibly missing firmware for module: aic94xx ==> WARNING: Possibly missing firmware for module: xhci_pci
Они появляются у большинства пользователей Arch Linux, так как соответствующие прошивки не поставляются пакетом . Если вы не используете устройства, которым нужны эти прошивки, вы можете игнорировать эти сообщения. На данный момент единственным решением для скрытия предупреждений модулей wd719x и aic94xx является установка пакетов с этими самыми прошивками. Для aic94xx установите . Для wd719x установите . Для xhci_pci установите upd72020x-fwAUR. Смотрите связанное обсуждение здесь.
Самые распространённые файлы прошивок поставляются пакетом . Другие файлы прошивок можно поискать в официальных репозиториях или AUR.
No PS/2 controller found
На некоторых материнских платах (в основном старых, но также и некоторых новых) контроллер i8042 не определяется автоматически. Это бывает редко, но некоторые люди всё же могут оказаться с неработающей клавиатурой. Вы можете заранее обнаружить эту ситуацию. Если у вас есть порт PS/2 и вы получаете сообщение , добавьте atkbd в массив .
Стандартная процедура восстановления
При неправильно сформированном начальном RAM-диске систему скорее всего не получится загрузить. В таком случае выполните описанную ниже процедуру восстановления системы:
Загрузка выполняется на одной машине и терпит неудачу на другой
hook скрипта mkinitcpio фильтрует ненужные модули ядра в первичном initramfs путем сканирования /sys и модулей, загруженных во время запуска. Если вы переносите /boot каталог на другую машину и последовательность загрузки терпит неудачу на стадии early userspace, то это может проиходить, потому что новое аппаратное обеспечение не определено отсутствующими модулями ядра. Обратите внимание, что для USB 2.0 и 3.0 нужны разные модули ядра.
Чтобы исправить, сначала попробуйте выбрать fallback образ в вашем загрузчике, поскольку он не фильтруется с помощью . После загрузки выполните mkinitcpio на новой машине, чтобы пересобрать первичный образ с корректными модулями. Если fallback образ не решил проблему, пропробуйте загрузиться в Arch Linux live CD/USB, выполнить chroot в установленную систему и выполнить mkinitcpio на новой машине. В крайнем случае, попробуйте вручную добавить модули в initramfs.
Смотрите также
- Документация ядра Linux: initramfs, "What is rootfs?"
- Документация ядра Linux: initrd
- Статья на Википедии: initrd