Kernel (Русский)

Дистрибутив Arch Linux основан на ядре Linux. Помимо основной стабильной (stable) версии в Arch Linux можно использовать некоторые альтернативные ядра. В статье описываются доступные в официальных репозиториях версии ядер, возможные патчи, а также способы, которыми пользователи могут скомпилировать собственное ядро.

Состояние перевода: На этой странице представлен перевод статьи Kernel. Дата последней синхронизации: 10 июля 2021. Вы можете помочь синхронизировать перевод, если в английской версии произошли изменения.

Из Википедии:

Ядро Linuxядро операционной системы, соответствующее стандартам POSIX, составляющее основу операционных систем семейства Linux.

Пакет ядра устанавливается в файловую систему в каталоге /boot/. Для загрузки нужного ядра при запуске системы необходимо соответствующим образом настроить загрузчик.

Официальные ядра

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

  • Stable "ванильное" ядро Linux с модулями и некоторыми патчами.
https://www.kernel.org/ || linux
  • Hardened ориентированное на безопасность ядро Linux с набором патчей, защищающих от эксплойтов ядра и пространства пользователя. Содержит больше защитных особенностей, чем linux.
https://github.com/anthraxx/linux-hardened || linux-hardened
  • Longterm ядро и модули с долгосрочной поддержкой (Long Term Support, LTS).
https://www.kernel.org/ || linux-lts

    Компиляция

    Скомпилировать собственное ядро можно двумя способами:

    /Arch Build System
    Преимущества — наличие готового PKGBUILD для пакета и удобство системы управления пакетами.
    /Традиционная компиляция
    Ручная загрузка архива файлов с исходными кодами ядра и их компиляция.

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

    Ядра kernel.org

    • Git ядро Linux, собранное из файлов с исходным кодом из git-репозитория Линуса Торвальдса.
    https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git || linux-gitAUR
    • Longterm 4.9 LTS-ядро версии 4.9.
    https://www.kernel.org/ || linux-lts49AUR
    • Longterm 5.4 LTS-ядро версии 5.4.
    https://www.kernel.org/ || linux-lts54AUR

    Неофициальные ядра

    • MultiPath TCP ядро с поддержкой Multipath TCP.
    https://multipath-tcp.org/ || linux-mptcpAUR
      • Realtime kernel поддерживается небольшой группой разработчиков, возглавляемой Ingo Molnar. Патч позволяет применять kernel preemption практически ко всему ядру за исключением небольших участков кода ("raw_spinlock critical regions"). Этого удалось добиться за счёт замены большинства спинлоков ядра на мьютексы с поддержкой наследования приоритета, а также перемещением всех прерываний (в том числе и программных) в потоки ядра.
      https://wiki.linuxfoundation.org/realtime/start || linux-rtAUR, linux-rt-ltsAUR

      Решение проблем

      Паника ядра

      Паника ядра (kernel panic) возникает, когда ядро Linux попадает в состояние невосстановимого сбоя. Это состояние обычно возникает из-за ошибок в драйверах оборудования, в результате чего система попадает в deadlock, не реагирует на запросы и требует перезагрузки. Непосредственно перед deadlock генерируется диагностическое сообщение, состоящее из: состояния компьютера, когда произошел сбой, трассировки (call trace), ведущей к функции ядра, распознавшей сбой, и списка загруженных в данный момент модулей. К счастью, паники ядра случаются нечасто при использовании основных версий ядра — таких, которые поставляются из официальных репозиториев — но когда они случаются, необходимо знать, как с ними бороться.

      Изучение сообщения паники

      Если паника ядра происходит очень рано в процессе загрузки, вы можете увидеть в консоли сообщение "Kernel panic - not syncing:", но после запуска systemd сообщения ядра обычно перехватываются и записываются в системный журнал. Однако, когда возникает паника, диагностическое сообщение, выдаваемое ядром, почти никогда не записывается в файл журнала на диске, потому что компьютер попадает в deadlock до того, как получит шанс записать журнал. Поэтому единственный способ просмотреть сообщение о панике — это просмотреть его на консоли в момент возникновения (не прибегая к установке kdump crashkernel). Вы можете сделать это, загрузившись со следующими параметрами ядра и попытавшись воспроизвести панику на tty1:

      systemd.journald.forward_to_console=1 console=tty1
      Пример сценария: плохой модуль

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

      • [1] Указывает тип ошибки, вызвавшей панику. В данном случае это была ошибка программиста.
      • [2] Указывает, что паника произошла в функции под названием fw_core_init в модуле firewire_core.
      • [3] Указывает, что firewire_core был последним загруженным модулем.
      • [4] Указывает, что функция, вызвавшая функцию fw_core_init, была do_one_initcall.
      • [5] Указывает на то, что это сообщение oops на самом деле является паникой ядра, и система ушла в deadlock.

      Мы можем предположить, что паника произошла во время инициализации модуля firewire_core при его загрузке. (Тогда можно предположить, что аппаратное обеспечение компьютера несовместимо с данной версией модуля драйвера firewire из-за ошибки программиста, и придётся ждать новой версии). Тем временем, самый простой способ заставить компьютер снова работать — это предотвратить загрузку проблемного модуля. Это можно сделать одним из двух способов:

      • Если модуль загружается в процессе работы initramfs, перезагрузитесь с параметром ядра .
      • Иначе перезагрузитесь с параметром ядра .

      Отладка регрессий

      См. General troubleshooting#Debugging regressions.

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

      Если проблема проявляется не слишком часто, то имеет смысл попробовать LTS-ядро (). Старые версии LTS-ядер можно найти в архиве Arch Linux.

      Если избавиться от проблемы не удалось, попробуйте локализовать баг в linux-gitAUR, после чего сообщите о нём в баг-трекер ядра. Важно проверять ванильное непропатченное ядро, чтобы убедиться, что причиной ошибки является не патч. Если проблемы вызывает патч, то сообщите об этом его автору.

      Смотрите также

      This article is issued from Archlinux. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.