GNU GRUB

редактировать
Пакет загрузчика

GNU GRUB
Логотип GNU GRUB Логотип GNU GRUB
GRUB v2, работающий в текстовом режиме GRUB v2, работающий в текстовом режиме
Исходный автор (ы) Эрих Болейн
Разработчик (и) Проект GNU
Первоначальный выпуск1995; 25 лет назад (1995 г.)
Стабильный выпуск 2.04 (GRUB 2) / 4 июля 2019 г.; 15 месяцев назад (04.07.2019)
Предварительный выпуск 2.04 ~ rc1 (GRUB 2) / 9 апреля 2019 г.; 18 месяцев назад (2019-04-09)
Репозиторий Отредактируйте это в Wikidata
Написано насборке, C
Операционная система Linux, macOS, BSD, Solaris (порт x86) и Windows (через цепную загрузку)
Платформа IA-32, x86-64, IA-64, ARM, PowerPC, s390x, MIPS и SPARC
Доступны наанглийском и других
типах Загрузчик
Лицензия GPLv3
Веб-сайтwww.gnu.org / software / grub /

GNU GRUB (сокращение от GNU GRand Unified Bootloader, обычно называемый GRUB ) - это пакет загрузчика из GNU Project. GRUB - это эталонная реализация спецификации мультизагрузки от Free Software Foundation, которая предоставляет пользователю выбор для загрузки одной из нескольких операционных систем установлен на компьютере, или выберите конкретную конфигурацию ядра, доступную в определенных разделах операционной системы.

GNU GRUB был разработан на основе пакета под названием Grand Unified Bootloader (игра на Grand Unified Theory ). Он преимущественно используется в Unix-подобных системах. Операционная система GNU использует GNU GRUB в качестве загрузчика, как и большинство дистрибутивов Linux и операционная система Solaris в системах x86, начиная с Solaris 10 1. / 06 выпуск.

GRUB часто используется как средство выбора ОС при запуске для компьютеров с двойной загрузкой, например, где одна система - Linux, а другая - Windows.

Содержание
  • 1 Операция
    • 1.1 Загрузка
    • 1.2 Версия 0 (GRUB Legacy)
    • 1.3 Версия 2 (GRUB 2)
      • 1.3.1 Запуск в системах с использованием прошивки BIOS
      • 1.3.2 Запуск в системах с прошивкой UEFI
      • 1.3.3 После запуска
  • 2 История
    • 2.1 Разработка
    • 2.2 Варианты
  • 3 Утилиты
    • 3.1 Инструменты конфигурации GRUB
    • 3.2 Утилиты восстановления загрузки
    • 3.3 Установщик для Windows
  • 4 Альтернативные менеджеры загрузки
  • 5 Внешние ссылки
    • 5.1 Инструкции и устранение неполадок
    • 5.2 Документация
    • 5.3 Вводные статьи
    • 5.4 Технические характеристики
    • 5.5 См. Также
  • 6 Ссылки
Операция
GRUB2 на жестком диске с разделами MBR ; этап 1 (boot.img) в качестве альтернативы может быть записан в один из загрузочных секторов раздела. GRUB2 на жестком диске с разделами GPT, загрузка с Микропрограмма BIOS или Режим совместимости с UEFI (CSM)

Загрузка

Когда компьютер включен, BIOS находит настроенное основное загрузочное устройство (обычно жесткий диск), загружает и выполняет начальную программу bootstrap из главной загрузочной записи (MBR). MBR - это первый сектор жесткого диска с нулевым смещением смещения (подсчет секторов начинается с нуля). Долгое время размер сектора составлял 512 байт, но с 2009 года доступны жесткие диски с размером сектора 4096 байт, называемые дисками расширенного формата. По состоянию на октябрь 2013 года такие жесткие диски по-прежнему доступны в 512-байтовых секторах с использованием эмуляции 512e.

Устаревшая таблица разделов MBR поддерживает максимум четыре раздела и занимает 64 байта, комбинированный. Вместе с необязательной дисковой подписью (четыре байта) и меткой времени диска (шесть байтов) это оставляет от 434 до 446 байтов, доступных для машинного кода загрузчик. Хотя такого небольшого пространства может хватить для очень простых загрузчиков, его недостаточно для размещения загрузчика, поддерживающего сложные и множественные файловые системы , выбор вариантов загрузки с помощью меню и т. Д. Загрузчики с Таким образом, более крупные посадочные места разделяются на части, причем самая маленькая часть помещается в MBR и находится в ней, в то время как более крупные части хранятся в других местах (например, в пустых секторах между MBR и первым разделом) и вызываются MBR-код загрузчика.

Операционная система ядро ​​ Образы в большинстве случаев представляют собой файлы, находящиеся в соответствующих файловых системах, но концепция файловой системы неизвестна BIOS. Таким образом, в системах на основе BIOS обязанностью загрузчика является доступ к содержимому этих файлов, чтобы его можно было загрузить в RAM и выполнить.

Одним из возможных подходов загрузчиков к загрузке образов ядра является прямой доступ к секторам жесткого диска без понимания основной файловой системы. Обычно требуется дополнительный уровень косвенного обращения в виде карт или файлов карт - вспомогательных файлов, содержащих список физических секторов, занятых образами ядра. Такие карты необходимо обновлять каждый раз, когда образ ядра меняет свое физическое местоположение на диске из-за установки новых образов ядра, дефрагментации файловой системы и т. Д. Кроме того, в случае изменения физического местоположения карт их местоположения необходимо обновить в пределах MBR-код загрузчика, поэтому механизм косвенного обращения к секторам продолжает работать. Это не только громоздко, но и оставляет систему в необходимости ручного ремонта на случай, если что-то пойдет не так во время обновления системы.

Другой подход - сделать загрузчик осведомленным о базовых файловых системах, чтобы образы ядра настраиваются и доступны с использованием их фактических путей к файлам. Для этого требуется, чтобы загрузчик содержал драйвер для каждой из поддерживаемых файловых систем, чтобы они могли быть поняты и доступны для самого загрузчика. Этот подход устраняет необходимость в жестко запрограммированных местоположениях секторов жесткого диска и существовании файлов карты, а также не требует обновления MBR после добавления или перемещения образов ядра. Конфигурация загрузчика хранится в обычном файле, доступ к которому также осуществляется с учетом требований файловой системы для получения конфигураций загрузки перед фактической загрузкой любых образов ядра. В результате вероятность того, что что-то пойдет не так во время различных обновлений системы, значительно снижается. Обратной стороной является то, что такие загрузчики увеличивают внутреннюю сложность и занимают еще больше места.

GNU GRUB использует второй подход, понимая лежащие в основе файловые системы. Сам загрузчик разделен на несколько этапов, что позволяет ему вписаться в схему загрузки MBR.

Обычно используются две основные версии GRUB: GRUB версии 1, называемой GRUB legacy, преобладает только в более старых версиях дистрибутивов Linux, некоторые из которых все еще используются и поддерживаются, например CentOS 5. GRUB 2 был написан с нуля и призван заменить своего предшественника и теперь используется в большинстве дистрибутивов Linux.

Версия 0 (GRUB Legacy)

Меню GRUB v1 (выполняется как часть установки Ubuntu 8.04)

GRUB 0.x следует двухэтапному подходу. Основная загрузочная запись (MBR) обычно содержит этап 1 GRUB или может содержать стандартную реализацию MBR, которая загружает по цепочке этап 1 GRUB из загрузочного сектора активного раздела . Учитывая небольшой размер загрузочного сектора (512 байт), этап 1 может сделать немного больше, чем загрузить следующий этап GRUB, загрузив несколько секторов диска из фиксированного места рядом с началом диска (в пределах его первых 1024 цилиндров).

Этап 1 может загружать этап 2 напрямую, но обычно он настроен на загрузку этапа 1.5., Расположенного в первых 30 КиБ жесткого диска сразу после MBR и перед первым раздел. Если это пространство недоступно (необычная таблица разделов, специальные драйверы диска, GPT или LVM диск), установка этапа 1.5 завершится ошибкой. Образ этапа 1.5 содержит драйверы файловой системы, что позволяет ему напрямую загружать этап 2 из любого известного места в файловой системе, например, из / boot / grub. Затем на этапе 2 будет загружен файл конфигурации по умолчанию и любые другие необходимые модули.

Версия 2 (GRUB 2)

GRUB 2 - разделение MBR по сравнению с GPT и визуализация последовательности загрузки (системы, использующие встроенное ПО BIOS).

Запуск в системах, использующих встроенное ПО BIOS
  • См. иллюстрация на последнем изображении справа.
  • 1-й этап: boot.imgзаписывается в первые 440 байтов главной загрузочной записи (MBR в секторе 0) или, необязательно, в загрузочном секторе раздела (PBR / VBR). Он адресует diskboot.imgс помощью 64-битного адреса LBA, таким образом, он может загружать данные, превышающие предел 2 ГиБ для MBR. Фактический номер сектора записывается grub-install.
  • 2-й этап: diskboot.img- это первый сектор core.img(называется этапом 1.5 в GRUB Legacy) с единственной целью - загрузить оставшуюся часть core.img, идентифицированную номерами секторов LBA, также записанными с помощью grub-install.
  • На MBR разделенных дисках: core.imgхранится в пустых секторах (если есть) между MBR и первым разделом. Последние операционные системы предлагают зазор в 1 Мбайт для выравнивания (2047 * 512 байт или 255 * 4 КиБ секторов). Раньше этот промежуток составлял 62 сектора (31 КиБ) в качестве напоминания об ограничении количества секторов C / H / S-адресации, которое использовалось Bios до 1998 года, поэтому core.imgразработан быть меньше 32 КиБ.
  • На GPT дисках с разделами: количество разделов не ограничено 4, поэтому core.imgзаписывается в свой крошечный (1 МиБ), без файловой системы загрузочный раздел BIOS.
  • 3-й этап: core.imgвходит в 32-битный защищенный режим, распаковывает себя (ядро grub и модули файловой системы для доступа к / boot / grub), затем загружает / boot / grub / /normal.modиз раздела, настроенного с помощью grub-install. Если индекс раздела изменился, GRUB не сможет найти normal.modи представляет пользователю приглашение GRUB Rescue, где пользователь «может» найти и загрузить normal.modили ядро ​​Linux.
  • Каталог / boot / grubможет быть расположен в любом разделе (GRUB может читать многие файловые системы, включая NTFS ). В зависимости от того, как он был установлен, он находится либо в корневом разделе дистрибутива, либо в отдельном / загрузочном разделе.
  • 4-й этап: normal.mod(эквивалент этапа 2 в GRUB Legacy) анализирует /boot/grub/grub.cfg, дополнительно загружает модули (например, для графического интерфейса пользователя) и показывает меню.

Запуск в системах, использующих прошивку UEFI
  • Обычное на материнских платах с ок. 2012.
  • / efi / /grubx64.efiустанавливается в виде файла в системном разделе EFI и загружается напрямую микропрограммой, без boot.imgв секторе 0.
  • / boot / grub /также может быть установлен на системный раздел EFI.

После запуска

GRUB представляет меню где пользователь может выбрать операционную систему (ОС), найденную с помощью grub-install. GRUB можно настроить на автоматическую загрузку указанной ОС по истечении заданного пользователем тайм-аута. Если тайм-аут установлен на ноль секунд, нажатие и удержание ⇧ Shiftво время загрузки компьютера позволяет получить доступ к меню загрузки.

В меню выбора операционной системы GRUB принимает пару из команд:

  • Нажав e, можно отредактировать параметры ядра выбранного пункта меню до запуска операционной системы. Причина для выполнения этого в GRUB (т. Е. Отказ от редактирования параметров в уже загруженной системе) может быть в аварийном случае: система не загрузилась. Используя строку параметров ядра, можно, среди прочего, указать модуль, который должен быть отключен (занесен в черный список) для ядра. Это может потребоваться, если конкретный модуль ядра сломан и, таким образом, препятствует загрузке. Например, чтобы внести в черный список модуль ядра nvidia-current, можно добавить modprobe.blacklist = nvidia-currentв конце параметров ядра.
  • Нажав c, пользователь входит в командную строку GRUB. Командная строка GRUB не является обычной оболочкой Linux, например, bash и принимает только определенные команды GRUB, задокументированные различными дистрибутивами Linux.

После выбора параметров загрузки GRUB загружает выбранное ядро ​​в память и передает управление ядру. В качестве альтернативы GRUB может передать управление процессом загрузки другому загрузчику, используя загрузку цепочки. Это метод, используемый для загрузки операционных систем, которые не поддерживают спецификацию мультизагрузки или не поддерживаются непосредственно GRUB.

История

GRUB изначально был разработан Эрихом Болейном как часть работы по загрузке операционной системы GNU / Hurd, разработанный Free Software Foundation. В 1999 году Гордон Мацигкейт и Ёсинори К. Окуджи сделали GRUB официальным программным пакетом GNU Project и открыли для общественности процесс разработки. По состоянию на 2014 год большинство дистрибутивов Linux приняли GNU GRUB 2, а также другие системы, такие как Sony PlayStation 4.

Development

GRUB версии 1 (также известной как «GRUB Legacy»). больше не разрабатывается и постепенно прекращается. Разработчики GNU GRUB переключились на GRUB 2, полную перезапись с целями, в том числе сделать GNU GRUB более чистым, надежным, портативным и мощным. GRUB 2 стартовал под именем PUPA . PUPA была поддержана Агентством продвижения информационных технологий (IPA) в Японии. PUPA была интегрирована в разработку GRUB 2 примерно в 2002 году, когда версия GRUB 0.9x была переименована в GRUB Legacy.

Некоторые из целей проекта GRUB 2 включают поддержку не-x86 платформ, интернационализации и локализации, символов не-ASCII, динамических модулей, управление памятью, скриптовый мини-язык, перенос специфичного для платформы (x86) кода на специфичные для платформы модули и объектно-ориентированная структура. GNU GRUB версии 2.00 был официально выпущен 26 июня 2012 года.

Три наиболее широко используемых дистрибутива Linux используют GRUB 2 в качестве основного загрузчика. Ubuntu принят он был загрузчиком по умолчанию в версии 9.10 от октября 2009 года. Fedora последовала его примеру с Fedora 16, выпущенной в ноябре 2011 года. OpenSUSE принял GRUB 2 в качестве загрузчика по умолчанию в своей версии 12.2. от сентября 2012 года. Solaris также принял GRUB 2 на платформе x86 в версии Solaris 11.1.

В конце 2015 года был обнаружен эксплойт, заключающийся в 28-кратном нажатии клавиши Backspace для обхода пароля входа и быстро исправлено.

Варианты

GNU GRUB - это бесплатное программное обеспечение с открытым исходным кодом, поэтому было создано несколько вариантов. Некоторые примечательные из них, которые не были объединены в основную ветку GRUB:

  • OpenSolaris включает модифицированный GRUB Legacy, который поддерживает метки дисков BSD, автоматический выбор 64-битного ядра и загрузку из ZFS. (со сжатием и несколькими загрузочными средами).
  • Google Summer of Code 2008 имел проект по поддержке устаревшей версии GRUB для загрузки с разделов, отформатированных в ext4.
  • В рамках проекта Syllable была создана модифицированная версия GRUB для загрузки системы из его файловой системы AtheOS.
  • TrustedGRUB расширяет GRUB, реализуя проверку целостности системы и безопасность процесса загрузки, с использованием Trusted Platform Module (TPM).
  • Intel BIOS Implementation Test Suite (BITS) предоставляет среду GRUB для тестирования BIOS и, в частности, их инициализации процессоров Intel, оборудования и технологий. BITS поддерживает создание сценариев через Python и включает API-интерфейсы Python для доступа к различным низкоуровневым функциям аппаратной платформы, включая ACPI, регистры процессора и набора микросхем, PCI и PCI Express.
  • GRUB4DOS была устаревшей версией GRUB. fork, который улучшает процесс установки в DOS и Microsoft Windows, помещая все, кроме конфигурации GRLDR, в один файл образа. Его можно загрузить с помощью Windows Boot Manager.
Utilities

инструментов конфигурации GRUB

StartUp-Manager, программы, используемой для настройки GRUB

Инструменты настройки, используемые различные дистрибутивы часто включают модули для настройки GRUB. Например, YaST2 в дистрибутивах SUSE Linux и openSUSE и Anaconda в Fedora / RHEL раздачи. StartUp-Manager и GRUB Customizer - это графические редакторы конфигурации для дистрибутивов на основе Debian. Разработка StartUp-Manager была остановлена ​​6 мая 2011 года после того, как ведущий разработчик привел личные причины неактивного развития программы. GRUB Customizer также доступен для дистрибутивов на основе Arch.

Для GRUB 2 существуют модули управления KDE.

GRLDR ICE - это крошечный инструмент для изменения конфигурации файла grldr по умолчанию для GRUB4DOS.

Утилиты восстановления загрузки

Boot-Repair - это простой графический инструмент для восстановления после частых проблем, связанных с загрузкой, с загрузчиком GRUB и Microsoft Windows. Это приложение доступно под лицензией GNU GPL. Boot-Repair может восстановить GRUB в нескольких дистрибутивах Linux, включая, помимо прочего, Debian, Ubuntu, Mint, Fedora, openSUSE и Arch Linux.

GRUB Customizer

Installer для Windows.

Grub2Win - это пакет программного обеспечения с открытым исходным кодом для Windows. Он позволяет GNU GRUB загружаться из каталога Windows. Программа установки устанавливает GNU GRUB версии 2.04 в раздел NTFS. Затем приложение Windows GUI используется для настройки меню загрузки GRUB, тем, порядка загрузки UEFI, сценариев и т. Д. Все сценарии и команды GNU GRUB поддерживаются как для UEFI, так и для устаревших систем. Grub2Win может настроить GRUB для мультизагрузки Windows, Ubuntu, openSuse, Fedora и многих других дистрибутивов Linux. Он находится в свободном доступе под лицензией GNU GPL на SourceForge.

Альтернативные менеджеры загрузки

Сильной стороной GRUB является широкий спектр поддерживаемых платформ, файловых систем и операционных систем. systems, что делает его выбором по умолчанию для дистрибутивов и встроенных систем.

Однако есть менеджеры загрузки, ориентированные на конечного пользователя, которые обеспечивают более удобный пользовательский интерфейс, графический селектор ОС и более простую конфигурацию:

  • rEFInd - графический менеджер загрузки в стиле Macintosh, только для Компьютеры на базе UEFI (BIOS не поддерживается).
  • CloverEFI - графический менеджер загрузки в стиле Macintosh для компьютеров на базе BIOS и UEFI. Эмулирует UEFI с сильно модифицированным DUET из проекта TianoCore. Требуется раздел в формате FAT даже в системах BIOS. В качестве преимущества он имеет базовый драйвер файловой системы в загрузочном секторе раздела, что позволяет избежать уязвимости 2-го и 3-го этапов GRUB и печально известного приглашения GRUB Rescue. Пользовательский интерфейс похож на rEFInd: оба наследуются от заброшенного диспетчера загрузки rEFIt.
  • BOOTBOOT - простой и легкий в использовании протокол загрузки только для 64 бит. Поддерживает BIOS, UEFI, ARM Raspberry Pi (3 и выше), El Torito CDROM, протокол загрузки Linux x86, дополнительные ПЗУ UEFI PCI и т. Д. Он также совместим с мультизагрузкой, поэтому его можно добавить в меню grub.cfg. Графический экран и последовательный порт (для сообщений отладки) настраиваются для ядра независимо от платформы. Для ядер ELF64 и PE32 +, поддерживаемых с привязкой более высокого уровня, а также примеры C / C ++ и Rust, предоставленные разработчикам ОС для любителей.

Альтернативы без графического представления:

  • systemd-boot - Легкая, загрузка только для UEFI- менеджер с текстовым меню выбора ОС.
Внешние ссылки
В Викиучебнике есть книга по теме: Установка GRUB после установки Windows

Инструкции и устранение неполадок

Вики-страницы распространения содержат множество решений для типичных проблем и пользовательских настроек, которые могут вам помочь:

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

Вводные статьи

Технические характеристики

См. также

  • Бесплатно и с открытым исходным кодом программный портал
Ссылки
Wikimedia Commons имеет носители, относящиеся к GNU GRUB.
Последняя правка сделана 2021-05-21 09:11:03
Содержание доступно по лицензии CC BY-SA 3.0 (если не указано иное).
Обратная связь: support@alphapedia.ru
Соглашение
О проекте