Make-initrd: различия между версиями

Материал из ALT Linux Wiki
 
(не показана 51 промежуточная версия 20 участников)
Строка 1: Строка 1:
{{DISPLAYTITLE:make-initrd}}
{{DISPLAYTITLE:make-initrd}}


'''make-initrd''' -- инструмент для сборки образов формата initramfs используемых для начальной загрузки ОС Linux.
'''make-initrd''' — инструмент для сборки образов формата initramfs, используемых для начальной загрузки ОС Linux.


== TODO ==
Проект состоит из двух основных частей:
* утилиты создания образа initramfs;
* утилит, работающих внутри образа в момент загрузки.
 
Утилита создания образа имеет модульную структуру. Основная её идея, что для создания образа необходимо (в простейшем случае) указать список особенностей (features) будущего образа. При этом порядок указания совершенно не важен. Пользователь не обязан знать как и в каком порядке будут применяться стадии и что они будут делать. Ему важно, чтобы, например, образ имел нужные модули ядра, имел bootsplash и был сжат определённым образом.
 
'''Внимание:''' Некоторые фичи поставляются в отдельных пакетах. При указании имени отсутствующей фичи ''ошибки не происходит''.
 
Основной иструмент в initrd это udev. Всё (или почти всё) делается через правила udev. Настройка сети, монтирование корневой директории. Всё.
 
== Загрузка ==
Init скрипт находится в корне образа (/init). Процесс загрузки разбит на несколько стадий. На самом деле, количество стадий не регламентировано.
 
Процессом загрузки можно управлять через параметры ядра:
 
'''ВНИМАНИЕ!''' Если нужно, чтобы stop или ignore сработали как можно раньше - нужно писать эти опции в ВЕРХНЕМ регистре, например stop -> STOP
 
* '''init'''=''<prog>'' -- параметр определяет программу init;
* '''quiet'''=''<1|0>'' -- включает/отключает отладочные сообщения;
* '''panic'''=''<1|0>'' -- разрешает/запрещает получение консоли при аварийных ситуациях;
* '''stop'''=''<stage-list>'' -- параметр определяет список стадий, перед которыми необходимо предоставить консоль (например stop=,all, или stop=,udev,);
* '''ignore'''=''<stage-list>'' -- список стадий, которые нужно пропустить;
* '''resume'''=''{<device>|UUID=...|LABEL=...}'' -- параметр определяет устройство, с которого будет производиться восстановление после спящего режима;
* '''root'''=''{<device>|UUID=...|LABEL=...|/dev/nfs}'' -- параметр определяет устройство, на котором находится корневая файловая система;
* '''rootdelay'''=''<sec>'' -- определяет время ожидания корневой файловой системы. Если за это время корень не будет найден, то загрузка продолжена не будет. По умолчанию этот параметр составляет 180 секунд;
* '''ip'''=''<client-ip>:<server-ip>:<gw-ip>:<netmask>:<hostname>:<device>:<proto>'' ,
* '''ip'''=''<device>:<proto>'' -- параметр описывает конфигурацию сетевых интерфейсов.
* '''RESCUE_MODULES'''="usbhid ehci_hcd hid_generic evdev ehci_pci ipmi_si" -- загрузить эти модули при вываливании в '''shell''' после указания stop=;
* '''nosplash''' -- не запускать plymouth
* '''rdshell''' -- загрузиться в initrd shell
 
== Отладка ==
=== общее ===
Добавьте в {{path|/etc/initrd.mk}} строчку <tt>VERBOSE = 1</tt> перед запуском сборки initrd.
 
Можно останавливать загрузку передачей параметра stop=<stage-list>, где список стадий:
<pre>
defaults
prepare
cmdline
fstab
network
preudev
udev
loop
stopudev
killall
cleanup
umount
sysinit
</pre>
 
=== udev ===
При "залипании" (на старте {{cmd|udevd}}) бывает полезно указать при загрузке опции <tt>rootdelay=3 stop=udev</tt> и запустить в полученном шелле {{cmd|udevd --debug --resolve-names&#61;never}} вручную; если проблема не вскрывается, может пригодиться сборка образа с добавленной в {{path|/etc/initrd.mk}} строчкой <tt>PUT_FILES += /usr/bin/strace</tt> и последующий запуск {{cmd|strace -ff -o /tmp/udev.strace -- udevd --debug --resolve-names&#61;never}}.  Для сохранения полученных данных может пригодиться, например, встроенный в ноутбук кардридер при <tt>MODULES_PRELOAD = sd_mod sdhci sdhci_pci mmc_block</tt>.
 
== Возможности ==
{| class="wide"
{| class="wide"
|-
|-
!Задача
! Статус
! style="width:15%;" | Статус
! Задача
|-
|-
|[http://git.altlinux.org/people/legion/packages/?p=make-initrd.git;a=tree;f=features/lvm lvm]
| align="center" | {{done}}
| align="center" | {{done}}
|[https://git.altlinux.org/people/legion/packages/?p=make-initrd.git;a=tree;f=make-initrd/features/lvm lvm]
|-
|-
|[http://git.altlinux.org/people/legion/packages/make-initrd.git?p=make-initrd.git;a=tree;f=features/raid raid]
| align="center" | {{done}}
| align="center" | {{done}}
|[https://git.altlinux.org/people/legion/packages/?p=make-initrd.git;a=tree;f=make-initrd/features/raid raid (autodetect)]
|-
|-
|[http://git.altlinux.org/people/legion/packages/make-initrd.git?p=make-initrd.git;a=tree;f=features/luks luks]
| align="center" | {{done}}
| align="center" | {{done}}
|[https://git.altlinux.org/people/legion/packages/?p=make-initrd.git;a=tree;f=make-initrd/features/mdadm raid (mdadm)]
|-
|-
|[http://git.altlinux.org/people/legion/packages/make-initrd.git?p=make-initrd.git;a=tree;f=features/multipath multipath]
| align="center" | {{done}}
| align="center" | {{done}}
|[https://git.altlinux.org/people/legion/packages/?p=make-initrd.git;a=tree;f=make-initrd/features/luks luks]
|-
|-
|[http://git.altlinux.org/people/legion/packages/make-initrd.git?p=make-initrd.git;a=tree;f=features/usb-storage usb]
| align="center" | {{done}}
| align="center" | {{done}}
|[https://git.altlinux.org/people/legion/packages/?p=make-initrd.git;a=tree;f=make-initrd/features/multipath multipath]
|-
|-
| align="center" | {{done}}
|[https://git.altlinux.org/people/legion/packages/?p=make-initrd.git;a=tree;f=make-initrd/features/usb-storage usb]
|-
| align="center" | {{done}}
|Настройка нескольких сетевых интерфейсов
|Настройка нескольких сетевых интерфейсов
|-
| align="center" | {{done}}
| align="center" | {{done}}
|[https://git.altlinux.org/people/legion/packages/?p=make-initrd.git;a=tree;f=make-initrd/features/nfsroot nfs] См. также '''nfsroot''' ниже.
|-
|-
|[http://git.altlinux.org/people/legion/packages/make-initrd.git?p=make-initrd.git;a=tree;f=features/nfsroot nfs]
| align="center" | {{done}}
| align="center" | {{done}}
|resume
|-
|-
|resume
| align="center" | {{done}}
| align="center" | {{done}}
|Поддержка рута на btrfs
|-
|-
|btrfs
| align="center" | {{done}}
|
|Поддержка systemd
|-
|-
|syslog
|align="center" | {{done}}
|
|[https://git.altlinux.org/people/legion/packages/?p=make-initrd.git;a=tree;f=make-initrd/features/syslog klog/syslog]
|-
|-
| align="center" | {{done}}
|bootsplash
|bootsplash
|
|-
|-
| autodetect modules
| align="center" | {{done}}
| align="center" | {{done}}
|[https://git.altlinux.org/people/legion/packages/?p=make-initrd.git;a=tree;f=make-initrd/features/plymouth plymouth]
|-
| align="center" | {{done}}
|Автодетект модулей
|-
|-
| align="center" | {{done}}
|Использовать [http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=blob;f=usr/gen_init_cpio.c gen_init_cpio] для создания cpio архива
|Использовать [http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=blob;f=usr/gen_init_cpio.c gen_init_cpio] для создания cpio архива
|-
| align="center" | {{done}}
| align="center" | {{done}}
|-
|Использование glibc и системных библиотек
|Использование glibc и системных библиотек
| align="center" | {{done}}
|-
|-
|(glibc) Использовать mdadm вместо md_run
|
|
|(glibc) Использовать nfs-utils вместо nfsmount
|-
| align="center" | {{done}}
|Создание нескольких образов за один вызов make-initrd. Это полезно, если в процессе обновления необходимо создать как initrd под текущую конфигурацию, так и образ с большим количеством модулей (утилит?) для более общей конфигурации.
|-
|-
|(glibc) Использовать nfs-utils вместо nfsmount
| align="center" | {{done}}
|
|Возможность монтировать не только корневую файловую систему.
|-
|-
|Создание нескольких образов за один вызыв make-initrd. Это полезно если в процессе обновления необходимо создать как initrd под текущую конфигурацию, так и образ с большим количеством модулей (утилит?) для более общий конфигурации.
| align="center" | {{done}}
| align="center" | {{done}}
|Возможность не указывать при загрузке параметры '''root''' / '''rootfstype''' / '''rootflags''', если загрузка идёт на той же системе, где был создан initrd.
|-
|-
| align="center" | {{done}}
|Поддержка работы с busybox. Для неё особенного ничего не нужно. Существует дополнительный [http://git.altlinux.org/people/legion/packages/make-initrd-busybox.git пакет] с собранным busybox расположенным в определённом месте, откуда его берёт make-initrd.
|
|}
|}
=== nfsroot ===
Фича {{term|nfsroot}} поставляется в пакете {{pkg|make-initrd-nfs}} и позволяет изготовить образ, пригодный для загрузки бездисковой машины по NFS. Для того, чтобы загрузка прошла правильно, при изготовлении образа в {{path|/etc/fstab}} для корневой точки монтирования должно быть записано:
    /dev/nfs / nfs <опции> 0 0
С таким корнем изготовление с конфигурацией по умолчанию не будет работать. Поэтому в {{path|/etc/initrd.mk}} нужно записать:
    AUTODETECT = all
    FEATURES = nfsroot
    DISABLE_GUESS = root
== ToDo ==
* Добавить поддержку zram/zcache.
* Добавить возможность монтирования корня с iscsi ([https://bugzilla.altlinux.org/show_bug.cgi?id=27354 ALT#27354]).
* Добавить возможность монтирования корня с bcache ([https://bugzilla.altlinux.org/show_bug.cgi?id=29561 ALT#29561]).
* Добавить фичу для генерации kdump.


== Документация ==
== Документация ==
[http://git.altlinux.org/people/legion/packages/make-initrd.git?p=make-initrd.git;a=blob;f=docs/README.ru README.ru]
* [https://github.com/osboot/make-initrd/wiki Documentation]
* [https://github.com/osboot/make-initrd/wiki/Features Features]
* [https://github.com/osboot/make-initrd/wiki/Configuration Configuration]
* [https://github.com/osboot/make-initrd/wiki/BootParameters Boot parameters]
* [https://habr.com/ru/companies/aktiv-company/articles/582606/ Весьма подробный обзор на Хабре]
 
Пример запуска регенерации initrd для текущего ядра:
make-initrd --kernel=`uname -r`
 
Не забудьте обновить кофигурацию загрузчика, если это необходимо (например, если у Вас LiLo).


== Исходный код ==
== Исходный код ==
* [http://git.altlinux.org/people/legion/packages/make-initrd.git make-initrd.git]
* [https://github.com/osboot/make-initrd make-initrd]
* [http://git.altlinux.org/people/legion/packages/kinit-utils.git kinit-utils.git]
* [http://git.altlinux.org/people/legion/packages/?p=make-initrd-busybox.git make-initrd-busybox.git] ''включён в 2.17.0''
* [http://git.altlinux.org/people/legion/packages/?p=kinit-utils.git kinit-utils.git]
 
== Рассылка ==
* [http://lists.altlinux.org/mailman/listinfo/make-initrd make-initrd@]


== Авторы ==
== Авторы ==
* Alexey Gladkov
* Alexey Gladkov
* Kirill A. Shutemov
* Kirill A. Shutemov


[[Категория:make-initrd]]
[[Категория:make-initrd]]
[[en:Make-initrd]]

Текущая версия от 04:46, 22 ноября 2024


make-initrd — инструмент для сборки образов формата initramfs, используемых для начальной загрузки ОС Linux.

Проект состоит из двух основных частей:

  • утилиты создания образа initramfs;
  • утилит, работающих внутри образа в момент загрузки.

Утилита создания образа имеет модульную структуру. Основная её идея, что для создания образа необходимо (в простейшем случае) указать список особенностей (features) будущего образа. При этом порядок указания совершенно не важен. Пользователь не обязан знать как и в каком порядке будут применяться стадии и что они будут делать. Ему важно, чтобы, например, образ имел нужные модули ядра, имел bootsplash и был сжат определённым образом.

Внимание: Некоторые фичи поставляются в отдельных пакетах. При указании имени отсутствующей фичи ошибки не происходит.

Основной иструмент в initrd это udev. Всё (или почти всё) делается через правила udev. Настройка сети, монтирование корневой директории. Всё.

Загрузка

Init скрипт находится в корне образа (/init). Процесс загрузки разбит на несколько стадий. На самом деле, количество стадий не регламентировано.

Процессом загрузки можно управлять через параметры ядра:

ВНИМАНИЕ! Если нужно, чтобы stop или ignore сработали как можно раньше - нужно писать эти опции в ВЕРХНЕМ регистре, например stop -> STOP

  • init=<prog> -- параметр определяет программу init;
  • quiet=<1|0> -- включает/отключает отладочные сообщения;
  • panic=<1|0> -- разрешает/запрещает получение консоли при аварийных ситуациях;
  • stop=<stage-list> -- параметр определяет список стадий, перед которыми необходимо предоставить консоль (например stop=,all, или stop=,udev,);
  • ignore=<stage-list> -- список стадий, которые нужно пропустить;
  • resume={<device>|UUID=...|LABEL=...} -- параметр определяет устройство, с которого будет производиться восстановление после спящего режима;
  • root={<device>|UUID=...|LABEL=...|/dev/nfs} -- параметр определяет устройство, на котором находится корневая файловая система;
  • rootdelay=<sec> -- определяет время ожидания корневой файловой системы. Если за это время корень не будет найден, то загрузка продолжена не будет. По умолчанию этот параметр составляет 180 секунд;
  • ip=<client-ip>:<server-ip>:<gw-ip>:<netmask>:<hostname>:<device>:<proto> ,
  • ip=<device>:<proto> -- параметр описывает конфигурацию сетевых интерфейсов.
  • RESCUE_MODULES="usbhid ehci_hcd hid_generic evdev ehci_pci ipmi_si" -- загрузить эти модули при вываливании в shell после указания stop=;
  • nosplash -- не запускать plymouth
  • rdshell -- загрузиться в initrd shell

Отладка

общее

Добавьте в /etc/initrd.mk строчку VERBOSE = 1 перед запуском сборки initrd.

Можно останавливать загрузку передачей параметра stop=<stage-list>, где список стадий:

defaults
prepare
cmdline
fstab
network
preudev
udev
loop
stopudev
killall
cleanup
umount
sysinit

udev

При "залипании" (на старте udevd) бывает полезно указать при загрузке опции rootdelay=3 stop=udev и запустить в полученном шелле udevd --debug --resolve-names=never вручную; если проблема не вскрывается, может пригодиться сборка образа с добавленной в /etc/initrd.mk строчкой PUT_FILES += /usr/bin/strace и последующий запуск strace -ff -o /tmp/udev.strace -- udevd --debug --resolve-names=never. Для сохранения полученных данных может пригодиться, например, встроенный в ноутбук кардридер при MODULES_PRELOAD = sd_mod sdhci sdhci_pci mmc_block.

Возможности

Статус Задача
Symbol kept vote.svg  lvm
Symbol kept vote.svg  raid (autodetect)
Symbol kept vote.svg  raid (mdadm)
Symbol kept vote.svg  luks
Symbol kept vote.svg  multipath
Symbol kept vote.svg  usb
Symbol kept vote.svg  Настройка нескольких сетевых интерфейсов
Symbol kept vote.svg  nfs См. также nfsroot ниже.
Symbol kept vote.svg  resume
Symbol kept vote.svg  Поддержка рута на btrfs
Symbol kept vote.svg  Поддержка systemd
Symbol kept vote.svg  klog/syslog
Symbol kept vote.svg  bootsplash
Symbol kept vote.svg  plymouth
Symbol kept vote.svg  Автодетект модулей
Symbol kept vote.svg  Использовать gen_init_cpio для создания cpio архива
Symbol kept vote.svg  Использование glibc и системных библиотек
(glibc) Использовать nfs-utils вместо nfsmount
Symbol kept vote.svg  Создание нескольких образов за один вызов make-initrd. Это полезно, если в процессе обновления необходимо создать как initrd под текущую конфигурацию, так и образ с большим количеством модулей (утилит?) для более общей конфигурации.
Symbol kept vote.svg  Возможность монтировать не только корневую файловую систему.
Symbol kept vote.svg  Возможность не указывать при загрузке параметры root / rootfstype / rootflags, если загрузка идёт на той же системе, где был создан initrd.
Symbol kept vote.svg  Поддержка работы с busybox. Для неё особенного ничего не нужно. Существует дополнительный пакет с собранным busybox расположенным в определённом месте, откуда его берёт make-initrd.

nfsroot

Фича nfsroot поставляется в пакете make-initrd-nfs и позволяет изготовить образ, пригодный для загрузки бездисковой машины по NFS. Для того, чтобы загрузка прошла правильно, при изготовлении образа в /etc/fstab для корневой точки монтирования должно быть записано:

   /dev/nfs / nfs <опции> 0 0

С таким корнем изготовление с конфигурацией по умолчанию не будет работать. Поэтому в /etc/initrd.mk нужно записать:

   AUTODETECT = all
   FEATURES = nfsroot
   DISABLE_GUESS = root

ToDo

  • Добавить поддержку zram/zcache.
  • Добавить возможность монтирования корня с iscsi (ALT#27354).
  • Добавить возможность монтирования корня с bcache (ALT#29561).
  • Добавить фичу для генерации kdump.

Документация

Пример запуска регенерации initrd для текущего ядра:

make-initrd --kernel=`uname -r`

Не забудьте обновить кофигурацию загрузчика, если это необходимо (например, если у Вас LiLo).

Исходный код

Рассылка

Авторы

  • Alexey Gladkov
  • Kirill A. Shutemov