Глава 10. Настройка ядра FreeBSD

Этот перевод может быть устаревшим. Для того, чтобы помочь с переводом, пожалуйста, обратитесь к Сервер переводов FreeBSD.

10.1. Обзор

Ядро — это основа операционной системы FreeBSD. Оно отвечает за управление памятью, обеспечение контроля безопасности, работу с сетью, доступ к дискам и многое другое. Хотя большая часть FreeBSD динамически настраивается, некоторые пользователи могут захотеть настроить и скомпилировать собственное ядро.

Прочитайте эту главу, чтобы узнать:

  • Когда следует собирать собственный ядро.

  • Как провести инвентаризацию оборудования.

  • Как настроить файл конфигурации ядра.

  • Как использовать файл конфигурации ядра для создания и сборки нового ядра.

  • Как установить новое ядро.

  • Как устранить неполадки, если что-то пойдет не так.

Все команды, приведенные в примерах этой главы, должны выполняться от имени пользователя root.

10.2. Зачем собирать собственное ядро?

Традиционно FreeBSD использовала монолитное ядро. Ядро представляло собой одну большую программу, поддерживало фиксированный список устройств, и для изменения его поведения необходимо было скомпилировать новое ядро, а затем перезагрузиться в него.

Сегодня большая часть функциональности ядра FreeBSD содержится в модулях, которые могут быть динамически загружены в ядро или выгружены из него по мере необходимости. Это позволяет работающему ядру немедленно адаптироваться к новому оборудованию и добавлять новую функциональность. Такое ядро называется модульным.

Время от времени всё ещё требуется выполнять статическую настройку ядра. Иногда необходимая функциональность настолько тесно связана с ядром, что её невозможно сделать динамически загружаемой. В некоторых средах с повышенными требованиями к безопасности запрещена загрузка и выгрузка модулей ядра, и требуется, чтобы только необходимая функциональность была статически скомпилирована в ядро.

Сборка собственного ядра часто является своего рода обрядом посвящения для опытных пользователей BSD. Этот процесс, хотя и отнимает много времени, может принести пользу системе FreeBSD. В отличие от ядра GENERIC, которое должно поддерживать широкий спектр оборудования, собственное ядро можно сократить до поддержки только аппаратного обеспечения данного компьютера. Это дает ряд преимуществ, таких как:

  • Более быстрая загрузка. Поскольку ядро будет проверять только оборудование, установленное в системе, время загрузки системы может сократиться.

  • Снижение использования памяти. Собственное ядро часто потребляет меньше памяти, чем ядро GENERIC, за счёт исключения неиспользуемых функций и драйверов устройств. Это важно, поскольку код ядра постоянно находится в физической памяти, не позволяя использовать эту память приложениям. По этой причине собственное ядро полезно на системах с небольшим объёмом оперативной памяти.

  • Дополнительная поддержка оборудования. Собственное ядро может добавить поддержку устройств, которые отсутствуют в ядре GENERIC.

При сборке собственного ядра важно учитывать, что нестандартные конфигурации тестируются менее тщательно, чем конфигурация GENERIC. Хотя настройка ядра может дать определённые преимущества, она также увеличивает риск возникновения проблем при сборке или во время работы. Пользовательские конфигурации ядра рекомендуются только опытным пользователям, у которых есть веская причина для внесения изменений и которые готовы при необходимости участвовать в процессе отладки.

Прежде чем собирать собственное ядро, стоит подумать о причине этого. Если требуется поддержка определённого оборудования, она может уже существовать в виде модуля.

Модули ядра находятся в /boot/kernel и могут быть динамически загружены в работающее ядро с помощью kldload(8). Большинство драйверов ядра имеют загружаемый модуль и страницу руководства. Например, драйвер беспроводной сети ath(4) содержит следующую информацию на своей странице руководства:

В качестве альтернативы, для загрузки драйвера в виде модуля при старте системы,
поместите следующую строку в loader.conf(5):

    if_ath_load="YES"

Добавление if_ath_load="YES" в /boot/loader.conf позволит динамически загрузить этот модуль во время загрузки системы.

В некоторых случаях связанный модуль отсутствует в /boot/kernel. Это в основном относится к определенным подсистемам.

10.3. Поиск информации об оборудовании системы

Прежде чем редактировать файл конфигурации ядра, рекомендуется составить перечень оборудования компьютера. На системе с двойной загрузкой этот перечень можно создать из другой операционной системы. Например, Диспетчер устройств Microsoft® содержит информацию об установленных устройствах.

Некоторые версии Microsoft® Windows® имеют значок "Система", который можно использовать для доступа к диспетчеру устройств.

Если FreeBSD — единственная установленная операционная система, используйте dmesg(8) для определения оборудования, обнаруженного и перечисленного во время загрузки. Большинство драйверов устройств в FreeBSD имеют справочную страницу, в которой перечислено поддерживаемое оборудование. Например, следующие строки указывают, что драйвер psm(4) обнаружил мышь:

psm0: <PS/2 Mouse> irq 12 on atkbdc0
psm0: [GIANT-LOCKED]
psm0: [ITHREAD]
psm0: model Generic PS/2 mouse, device ID 0

Поскольку данное оборудование существует, этот драйвер не следует удалять из файла конфигурации собственного ядра.

Если вывод команды dmesg не отображает результаты загрузочного probing, вместо этого прочитайте содержимое файла /var/run/dmesg.boot.

Еще один инструмент для поиска оборудования — это pciconf(8), который предоставляет более подробный вывод. Например:

% pciconf -lv
ath0@pci0:3:0:0:        class=0x020000 card=0x058a1014 chip=0x1014168c rev=0x01 hdr=0x00
    vendor     = 'Atheros Communications Inc.'
    device     = 'AR5212 Atheros AR5212 802.11abg wireless'
    class      = network
    subclass   = ethernet

Этот вывод показывает, что драйвер ath обнаружил беспроводное Ethernet-устройство.

Флаг -k утилиты man(1) может быть полезен для получения информации. Например, с его помощью можно вывести список страниц руководства, содержащих определённое название или марку устройства:

# man -k Atheros
ath(4)                   - Atheros IEEE 802.11 wireless network driver
ath_hal(4)               - Atheros Hardware Access Layer (HAL)

После составления списка оборудования обратитесь к нему, чтобы убедиться, что драйверы установленного оборудования не будут удалены при редактировании конфигурации собственного ядра.

10.4. Файл конфигурации

Для создания файла конфигурации собственного ядра и сборки кастомного ядра необходимо сначала установить полное дерево исходных кодов FreeBSD.

Если /usr/src/ не существует или пуст, исходный код не установлен. Исходный код можно установить с помощью Git, следуя инструкциям в “Использование Git”.

После установки исходного кода ознакомьтесь с содержимым каталога /usr/src/sys. Этот каталог содержит несколько подкаталогов, включая те, которые соответствуют следующим поддерживаемым архитектурам: amd64, i386, powerpc и sparc64. Всё содержимое каталога конкретной архитектуры относится только к этой архитектуре, а остальной код является машинонезависимым и общим для всех платформ. Каждая поддерживаемая архитектура имеет подкаталог conf, который содержит файл конфигурации ядра GENERIC для данной архитектуры.

Не вносите изменения в файл GENERIC. Вместо этого скопируйте его под другим именем и редактируйте копию. По сложившейся практике имя файла должно состоять из заглавных букв. Если вы обслуживаете несколько машин FreeBSD с разным оборудованием, разумно назвать файл по имени хоста соответствующей машины. В следующем примере создаётся копия файла конфигурации GENERIC для архитектуры amd64 с именем MYKERNEL:

# cd /usr/src/sys/amd64/conf
# cp GENERIC MYKERNEL

MYKERNEL теперь можно настроить с помощью любого текстового редактора, поддерживающего ASCII. Редактор по умолчанию — vi, но для новичков также установлен более простой редактор под названием ee.

Формат файла конфигурации ядра прост. Каждая строка содержит ключевое слово, представляющее устройство или подсистему, аргумент и краткое описание. Любой текст после # считается комментарием и игнорируется. Чтобы удалить поддержку устройства или подсистемы в ядре, поставьте # в начале строки, соответствующей этому устройству или подсистеме. Не добавляйте и не удаляйте # для строк, которые не понятны.

Легко удалить поддержку устройства или опции и получить нерабочее ядро. Например, если драйвер ata(4) удалён из конфигурационного файла ядра, система, использующая драйверы дисков ATA, может не загрузиться. Если сомневаетесь — оставьте поддержку в ядре.

В дополнение к кратким описаниям, приведённым в этом файле, дополнительные описания содержатся в NOTES, которые можно найти в том же каталоге, что и GENERIC для данной архитектуры. Для архитектурно-независимых параметров обратитесь к /usr/src/sys/conf/NOTES.

После завершения настройки конфигурационного файла ядра сохраните резервную копию в расположении за пределами /usr/src.

Или можно сохранить файл конфигурации ядра в другом месте и создать символическую ссылку на него:

# cd /usr/src/sys/amd64/conf
# mkdir /root/kernels
# cp GENERIC /root/kernels/MYKERNEL
# ln -s /root/kernels/MYKERNEL

В конфигурационных файлах доступна директива include, которая позволяет включать содержимое другого конфигурационного файла в текущий. Это упрощает поддержку небольших изменений относительно существующего файла. Если требуется лишь несколько дополнительных параметров или драйверов, можно сохранять разницу относительно GENERIC, как показано в примере:

include GENERIC
ident MYKERNEL

options         IPFIREWALL
options         DUMMYNET
options         IPFIREWALL_DEFAULT_TO_ACCEPT
options         IPDIVERT

При использовании этого метода локальный конфигурационный файл отражает локальные отличия от ядра GENERIC. При выполнении обновлений новые функции, добавленные в GENERIC, также будут добавлены в локальное ядро, если они не запрещены явно с помощью nooptions или nodevice. Полный список директив конфигурации и их описания можно найти в config(5).

Чтобы создать файл, содержащий все доступные параметры, выполните следующую команду от имени root:

# cd /usr/src/sys/arch/conf && make LINT

10.5. Сборка и установка собственного ядра

После сохранения изменений в пользовательском конфигурационном файле исходный код ядра можно скомпилировать, выполнив следующие шаги:

Процедура: Сборка ядра

  1. Перейдите в этот каталог:

    # cd /usr/src
  2. Соберите новое ядро, указав имя файла конфигурации собственного ядра:

    # make buildkernel KERNCONF=MYKERNEL
  3. Установите новое ядро, связанное с указанным файлом конфигурации ядра. Эта команда скопирует новое ядро в /boot/kernel/kernel, а старое ядро сохранит в /boot/kernel.old/kernel:

    # make installkernel KERNCONF=MYKERNEL
  4. Выключите систему и перезагрузитесь с новым ядром. Если возникнут проблемы, обратитесь к разделу Ядро не загружается.

По умолчанию при компиляции собственного ядра все модули ядра пересобираются. Чтобы ускорить обновление ядра или собрать только необходимые модули, отредактируйте /etc/make.conf перед началом сборки ядра.

Например, эта переменная задаёт список модулей для сборки вместо использования значения по умолчанию (сборка всех модулей):

MODULES_OVERRIDE = linux acpi

Или эта переменная указывает, какие модули исключить из процесса сборки:

WITHOUT_MODULES = linux acpi sound

Доступны дополнительные переменные. Подробности смотрите в make.conf(5).

10.6. Если что-то пойдет не так

Существует четыре типа проблем, которые могут возникнуть при сборке собственного ядра:

config завершается с ошибкой

Если config завершается с ошибкой, он выводит номер строки, содержащей ошибку. Например, при получении следующего сообщения убедитесь, что строка 17 введена правильно, сравнив её с GENERIC или NOTES:

config: line 17: syntax error
make завершается с ошибкой

Если make завершается с ошибкой, обычно это связано с ошибкой в файле конфигурации ядра, которую config не смог обнаружить. Проверьте конфигурацию, и если проблема не очевидна, отправьте письмо в список рассылки Список рассылки, посвящённый вопросам и ответам пользователей FreeBSD, приложив файл конфигурации ядра.

Ядро не загружается

Если новый ядро не загружается или не распознаёт устройства, не паникуйте! К счастью, в FreeBSD есть отличный механизм восстановления после проблем с несовместимыми ядрами. Просто выберите ядро для загрузки в загрузчике FreeBSD. Это можно сделать при появлении меню загрузки системы, выбрав опцию «Escape to a loader prompt». В командной строке введите boot kernel.old или имя любого другого ядра, которое заведомо загружается правильно.

После загрузки с исправным ядром проверьте конфигурационный файл и попробуйте собрать его снова. Полезным ресурсом может быть /var/log/messages, где записываются сообщения ядра при каждой успешной загрузке. Также dmesg(8) выведет сообщения ядра текущей загрузки.

При устранении неполадок ядра обязательно сохраняйте копию работоспособного ядра, например, GENERIC. Это важно, потому что при каждой установке нового ядра файл kernel.old перезаписывается последним установленным ядром, которое может быть или не быть загружаемым. Как можно скорее переместите рабочее ядро, переименовав каталог, содержащий исправное ядро:

# mv /boot/kernel /boot/kernel.bad
# mv /boot/kernel.good /boot/kernel
Ядро работает, но ps(1) — нет

Если версия ядра отличается от той, с которой собраны системные утилиты, например, при установке ядра, собранного из исходников -CURRENT, на систему -RELEASE, многие команды для просмотра состояния системы, такие как ps(1) и vmstat(8), не будут работать. Чтобы исправить это, пересоберите и установите world, собранный из той же версии исходного дерева, что и ядро. Никогда не рекомендуется использовать версию ядра, отличную от остальной операционной системы.


Изменено: 24 ноября 2025 г. by Vladlen Popolitov