systemd (Русский)
Ссылки по теме
- Systemd/Пользователь
- Systemd/Таймеры
- Systemd/Журнал
- systemd/FAQ
- init
- Демоны
- udev (Русский)
- Improving performance/Boot process
- Разрешить пользователям выключение системы Цитата с веб-страницы проекта:
- systemd — набор базовых компонентов Linux-системы. Представляет собой менеджер системы и служб, который выполняется как процесс с PID 1 и запускает остальную часть системы. systemd обеспечивает возможности агрессивной параллелизации, сокетную и D-Bus активацию для запуска служб, запуск демонов по запросу, отслеживание процессов с помощью контрольных групп Linux, обслуживание точек (авто)монтирования, а также предлагает развитую транзакционную логику управления службами на основе зависимостей. systemd поддерживает сценарии инициализации SysV и LSB и работает как замена sysvinit. Среди прочих элементов и функций — демон журнала, утилиты управления базовой конфигурацией системы (имя хоста, дата, языковой стандарт), ведение списков вошедших в систему пользователей, запущенных контейнеров, виртуальных машин, системных учётных записей, каталогов и настроек времени выполнения, а также демоны для управления несложными сетевыми конфигурациями, синхронизации времени по сети, пересылки журналов и разрешения имён.
- Для управления systemd на удалённой машине команды необходимо выполнять с ключом
-H пользователь@хост
. Соединение с удалённым процессом systemd будет установлено через SSH. - В Plasma для systemctl разработан графический интерфейс systemd-kcmAUR. После установки соответствующий модуль появится в разделе System administration.
- Если суффикс не указан, systemctl предполагает, что это .service. Например, равнозначно .
- Точки монтирования автоматически преобразуются в юнит .mount. Например, равнозначно .
- Аналогично точкам монтрования, имена устройств автоматически преобразуются в юнит .device. Например, равнозначно .
- Большинство команд ниже также будут работать, если указать несколько юнитов; подробнее см. systemctl(1).
- Опция
--now
в командахenable
,disable
иmask
соответственно запускает, останавливает или маскировует указанный юнит сразу при выполнении команды, а не после перезагрузки. - Пакеты могут содержать собственные юниты для различных целей. Если вы только что установили пакет, выполните
pacman -Qql название_пакета | grep -Fe .service -e .socket
, чтобы их найти. - В руководстве systemd.unit(5) § UNIT FILE LOAD PATH приведён перечень каталогов, в которых могут храниться файлы юнитов.
- Перезагружаются только настройки systemd, но не юнитов. Для юнитов необходимо использовать команду reload.
- Например, если раздел изменился с момента последнего включения.
- Как вручную, так и по зависимости, что делает маскировку несколько опасной.
/usr/lib/systemd/system/
: юниты, добавленные пакетами при установке;- : юниты, созданные системным администратором.
- При запуске systemd в пользовательском режиме пути загрузки будут отличаться.
- Названия юнитов могут содержать только буквы и цифры ASCII-набора, подчёркивания и точки. Другие символы должны быть экранированы в C-стиле ("\x2d") или использоваться исключительно в рамках определённой семантики ('@', '-'). Подробнее см. systemd.unit(5) и systemd-escape(1).
- (по умолчанию): systemd запустит эту службу незамедлительно. Процесс при этом не должен разветвляться (fork). Если после данной службы должны запускаться другие, то этот тип использовать не стоит (исключение — служба использует сокетную активацию).
- : systemd считает службу запущенной после того, как процесс разветвляется с завершением родительского процесса. Используется для запуска классических демонов за исключением тех случаев, когда в таком поведении процесса нет необходимости. Укажите параметр , чтобы systemd мог отслеживать основной процесс.
Type=oneshot
: удобен для сценариев, которые выполняют одно задание и завершаются. Если задать параметр , то systemd будет считать процесс активным даже после его завершения.- : идентичен параметру , но с уточнением, что демон пошлет systemd сигнал готовности. Реализация уведомления находится в библиотеке libsystemd-daemon.so.
- : служба считается находящейся в состоянии готовности после появления указанного
BusName
в системной шине DBus. - : systemd отложит выполнение двоичного файла службы до окончания запуска остальных ("более срочных") задач. В остальном поведение аналогично .
- (что примерно соответствует прежнему уровню запуска 3).
- (что примерно соответствует прежнему уровню запуска 1).
- Параметр ядра, описанный выше.
- Символическая ссылка
/etc/systemd/system/default.target
. - Символическая ссылка .
- systemd-boot — простой менеджер загрузки для UEFI;
- systemd-firstboot — инициализация системных настроек при первой загрузке;
- systemd-homed — переносимые аккаунты пользователей;
- systemd-logind — управление сеансами;
- systemd-networkd — управление сетевыми настройками;
- systemd-nspawn — приложение для контейнеризации процессов;
- systemd-resolved — разрешение сетевых имён;
- — создание системных пользователей/групп и добавление пользователей в группы при установке пакетов и загрузке системы;
- systemd-timesyncd — синхронизация системных часов по сети;
- systemd/Журнал — системные логи;
- systemd/Таймеры — таймеры для управления событиями и службами, альтернатива cron.
- Загрузчик должен установить EFI-переменную LoaderDevicePartUUID, по которой можно будет определить системный раздел EFI. Эта возможность поддерживается в systemd-boot, а также в rEFInd (по умолчанию отключена). Это проверяется наличием строки в выводе команды .
- Корневой раздел должен быть на одном физическом диске с системным разделом EFI. Автомонтируемые разделы должны быть на одном физическом диске с корневым разделом. Очевидно, монтируемые разделы должны оказаться на одном диске и с ESP.
- В NetworkManager служба включается вместе с . Проверить состояние службы можно командой . Если служба не включена, то включите заново ещё раз.
- В случае netctl включите службу .
- Для пользователей systemd-networkd юнит
systemd-networkd-wait-online.service
включается вместе со службой ; проверьте это командой . Если нет, то включите заново . - Параметр определяет список разрешённых capabilities, но с его помощью можно также и запрещать некоторые capabilities для определённого юнита.
- Например, можно задать capability , необходимую для создания безопасной песочницы:
- Wikipedia:ru:systemd
- Официальный веб-сайт (англ.)
- Страницы справочных руководств (англ.)
- Другие дистрибутивы
- Gentoo:Systemd
- Fedora:Systemd
- Fedora:How to debug Systemd problems — отладка systemd.
- Fedora:SysVinit to Systemd Cheatsheet — памятка по переходу с SysVinit на systemd.
- Debian:systemd
- Блог Lennart'а (англ.), update 1, update 2, update 3, Why systemd?
- Debug Systemd Services — отладка юнитов systemd.
- systemd для администраторов (PDF) - перевод цикла статей Леннарта Поттеринга (Lennart Poettering)
- How To Use Systemctl to Manage Systemd Services and Units
- Session management with systemd-logind
- Emacs Syntax highlighting for Systemd files (англ.)
- часть 1 и часть 2 вводной статьи в журнале The H Open (англ.)
Основы использования systemctl
Главная команда для работы с systemd — systemctl. Она позволяет (среди прочего) отлеживать состояние системы и управлять системой и службами. Подробнее см. .
Использование юнитов
Юнитами могут быть, например, службы (.service), точки монтирования (.mount), устройства (.device) или сокеты (.socket).
При работе с systemctl обычно необходимо указывать полное имя юнита с суффиксом, например, sshd.socket
. Существует несколько возможных сокращений:
Подробнее см. .
Действие | Команда | Примечание |
---|---|---|
Анализ состояния системы | ||
Состояние системы | $ systemctl status | |
Список запущенных юнитов | или | |
Список юнитов, запустить которые не удалось | ||
Список установленных файлов юнитов1 | ||
Информация о процессе по его PID | cgroup slice, занимаемая память и родительский процесс | |
Состояние юнита | ||
Страница руководства юнита | если юнит её предоставляет | |
Состояние юнита | в т. ч. работает ли он в данный момент | |
Проверить, добавлен ли юнит в автозапуск | $ systemctl is-enabled юнит | |
Запуск, перезапуск, перезагрузка юнита | ||
Незамедлительно запустить юнит | ||
Незамедлительно остановить юнит | # systemctl stop юнит | |
Перезапустить юнит | ||
Перезагрузить юнит с новыми настройками | ||
Перезагрузить настройки systemd2 | сканировать систему на наличие новых или изменённых юнитов | |
Включение юнита (автозапуск) | ||
Включить юнит, добавив его в автозапуск | ||
Включить юнит и сразу запустить | ||
Отключить юнит | ||
Включить юнит заново3 | т.е. отключить и снова включить | |
Маскировка юнита | ||
Замаскировать юнит, сделав невозможным его запуск4 | # systemctl mask юнит | |
Снять маскировку юнита |
Управление питанием
Для управления питанием от имени непривилегированного пользователя необходим polkit. Если вы находитесь в локальном пользовательском сеансе systemd-logind и нет других активных сеансов, приведенные ниже команды сработают, даже если будут выполнены не от root. В противном случае (например, другой пользователь вошел в систему через tty) systemd автоматически запросит у вас пароль суперпользователя.
Действие | Команда |
---|---|
Завершить работу и перезагрузить систему | |
Завершить работу и выключить компьютер | |
Перевести систему в ждущий режим | |
Перевести систему в спящий режим | |
Перевести систему в режим гибридного сна (suspend-to-both) |
Написание файлов юнитов
Синтаксис файлов юнитов systemd (см. ) вдохновлён desktop-файлами XDG Desktop Entry Specification, а они, в свою очередь, основаны на синтаксисе файлов .ini Microsoft Windows. Файлы юнитов загружаются из целого ряда мест (команда выведет полный список), ключевыми из которых являются следующие (в порядке увеличения приоритета):
При создании собственных юнитов за образец можно взять юниты установленных пакетов или примеры из .
Обработка зависимостей
В systemd зависимости определяются правильным построением файлов юнитов. Простой пример — юниту A требуется, чтобы юнит B был запущен перед запуском самого юнита A. Для этого добавьте строки и в раздел юнит-файла A. Если зависимость является необязательной, укажите и соответственно. Обратите внимание, что и Requires=
не подразумевают . Если не указать, то юниты будут запущены параллельно.
Зависимости обычно указываются для служб, но не для целей. Так, цель будет "подтянута" ещё на этапе настройки сетевых интерфейсов одной из соответствующих служб, и можно спокойно указывать эту цель как зависимость в пользовательской службе, поскольку будет запущена в любом случае.
Типы служб
Службы различаются по типу запуска, и это следует учитывать при написании юнитов. Тип определяется параметром в разделе :
Подробнее о параметре см. .
Редактирование файлов юнитов
Не стоит редактировать юнит-файлы пакетов напрямую, так как это приведёт к конфликтам с pacman. Есть два безопасных способа редактирования: создать новый файл, который полностью заменит оригинальный, или создать drop-in файл, который будет применяться поверх оригинального юнита. В обоих случаях после редактирования необходимо перезагрузить юнит, чтобы изменения вступили в силу. Это выполняется либо путем редактирования блока с помощью команды , которая автоматически перезагружает юнит, либо перезагрузкой всех юнитов командой:
# systemctl daemon-reloadЗамещение файла юнита
Чтобы полностью заместить файл юнита , создайте файл с таким же именем /etc/systemd/system/юнит
и включите заново юнит для обновления символических ссылок.
Альтернативный способ:
# systemctl edit --full юнитЭта команда откроет файл /etc/systemd/system/юнит
в текстовом редакторе (если файл ещё не существует, будет скопирован оригинал) и автоматически перезагрузит юнит после завершения редактирования.
Drop-in файлы
Чтобы создать drop-in файл для , создайте каталог и поместите в него файлы .conf с добавленными или изменёнными опциями. systemd будет анализировать эти файлы и применять их поверх оригинального юнита.
Самый простой способ — использовать команду:
# systemctl edit юнитКоманда откроет /etc/systemd/system/юнит.d/override.conf
в текстовом редакторе (файл будет создан, если его ещё нет) и автоматически перезапустит юнит после завершения редактирования.
Откат изменений
Отменить все изменения, сделанные с помощью , можно командой:
# systemctl revert юнитПримеры
Например, если вы просто хотите добавить дополнительную зависимость к юниту, можно создать следующий файл:
Другой пример: для замены в юните (кроме типа ) создайте следующий файл:
Обратите внимание, что необходимо очистить перед присвоением нового значения . Это относится ко всем параметрам, которые позволяют прописать несколько значений, вроде в таймерах.
Пример настройки автоматического перезапуска службы:
Цели
Systemd использует юнит типа цель (target) для группировки юнитов по зависимостям и в качестве стандартизированных точек синхронизации. Они выполняют ту же задачу, что и уровни запуска, но действуют немного по-другому. Каждая цель имеет имя, а не номер, и предназначена для конкретных задач; несколько целей могут быть активны одновременно. Некоторые цели реализованы путём наследования служб из других целей с добавлением собственных. В systemd также имеются цели, имитирующие общие уровни запуска SystemVinit, поэтому вы можете переключаться между целями, используя привычную команду telinit RUNLEVEL
.
Получение информации о текущих целях
В systemd для этого предназначена следующая команда (заменяющая ):
$ systemctl list-units --type=targetСоздание пользовательской цели
Уровни запуска, имеющие определённое значение в sysvinit (0, 1, 3, 5 и 6), один в один соответствуют конкретным целям systemd. К сожалению, не существует хорошего способа сделать то же самое для пользовательских уровней 2 и 4. Их использование предполагает, что вы создаёте новый юнит-цель с названием , который берет за основу один из существующих уровней запуска (взгляните, например, на ), создаёте каталог /etc/systemd/system/цель.wants
, а после этого — символические ссылки на те службы из каталога /usr/lib/systemd/system/
, которые вы хотите включить при загрузке.
Соответствие уровней SysV целям systemd
Уровнень запуска SysV | Цель systemd | Примечания |
---|---|---|
0 | runlevel0.target, poweroff.target | Выключение системы |
1, s, single | runlevel1.target, rescue.target | Однопользовательский уровень запуска |
2, 4 | runlevel2.target, runlevel4.target, multi-user.target | Уровни запуска, определенные пользователем/специфичные для узла. По умолчанию соответствует уровню запуска 3 |
3 | runlevel3.target, multi-user.target | Многопользовательский режим без графики. Пользователи, как правило, входят в систему при помощи множества консолей или через сеть |
5 | runlevel5.target, graphical.target | Многопользовательский режим с графикой. Обычно эквивалентен запуску всех служб на уровне 3 и графического менеджера входа в систему |
6 | runlevel6.target, reboot.target | Перезагрузка |
emergency | emergency.target | Аварийная оболочка |
Изменение текущей цели
В systemd цели доступны посредством целевых юнитов. Вы можете переключать их такой командой:
# systemctl isolate graphical.targetДанная команда только изменит текущую цель и не повлияет на следующую загрузку системы. Она соответствует командам Sysvinit вида и .
Изменение цели загрузки по умолчанию
Стандартная цель — , которая по умолчанию ссылается на (примерно соответствующего прежнему уровню запуска 5).
Узнать текущую цель можно так:
$ systemctl get-defaultДля установки новой цели загрузки по умолчанию измените ссылку . С помощью команды systemctl это делается так:
Альтернативный способ — добавить один из следующих параметров ядра в загрузчик:
Порядок выбора цели по умолчанию
systemd выбирает в следующем порядке :
Компоненты systemd
Некоторые (не все) составные части systemd:
systemd.mount — монтирование
systemd полностью отвечает за монтирование разделов и файловых систем, описанных в файле . преобразует записи из в юниты systemd; это выполняется при каждой загрузке системы, а также при перезагрузке конфигурации системного менеджера.
systemd расширяет возможности fstab и предлагает дополнительные опции монтирования. Они могут влиять на зависимости юнита монтирования: например, могут гарантировать, что монтирование выполняется только после подключения к сети или после монтирования другого раздела. Полный список опций монтирования systemd (обычно они имеют префикс x-systemd
) описан в .
Примером этих опций может быть т.н. автомонтирование (здесь имеется в виду не автоматическое монтирование во время загрузки, а монтирование при появлении запроса от устройства). Подробнее смотрите fstab#Автоматическое монтирование с systemd.
Автомонтирование GPT-раздела
На UEFI-системах автоматически монтирует GPT-разделы в соответствии с Discoverable Partitions Specification, поэтому их можно не указывать в файле fstab.
Требования:
/var
Для автомонтирования раздела его PARTUUID должен совпадать с хэш-суммой SHA256 HMAC, вычисленной на основании UUID типа раздела. В качестве ключа хэша используется machine ID. Необходимый PARTUUID можно получить командой:
$ systemd-id128 -u --app-specific=4d21b016-b534-45c2-a9fb-5c16e091fd2d machine-idsystemd-sysvcompat
Пакет (зависимость пакета ) содержит традиционный бинарный файл init. В системах под управлением systemd — символическая ссылка на исполняемый файл systemd
.
Кроме того, в этом пакете находятся 4 команды SysVinit — , , и shutdown(8). Это символические ссылки на , и их работа обусловлена логикой systemd. Подробнее см. #Управление питанием.
В systemd-системах отказаться от совместимости с System V можно либо задав параметр загрузки (см. BBS#233387), либо с помощью собственных аргументов команды .
systemd-tmpfiles — временные файлы
Утилита systemd-tmpfiles создает, удаляет и очищает непостоянные и временные файлы и каталоги. Она читает конфигурационные файлы из и , чтобы понять, что необходимо делать. Конфигурационные файлы в первом каталоге имеют приоритет над теми, что расположены во втором.
Конфигурационные файлы обычно предоставляются вместе с файлами служб и имеют названия вида . Например, демон Samba предполагает, что существует каталог /run/samba
с корректными правами доступа. Поэтому пакет поставляется в следующей конфигурации:
Конфигурационные файлы также могут использоваться для записи значений при старте системы. Например, если вы используете для отключения пробуждения от устройств USB при помощи , вместо этого вы можете использовать следующий tmpfile:
/etc/tmpfiles.d/disable-usb-wake.conf
# Path Mode UID GID Age Argument w /proc/acpi/wakeup - - - - USBE
Подробнее смотрите и .
Советы и рекомендации
Программы настройки с графическим интерфейсом
Запуск сервисов после подключения к сети
Чтобы запустить сервис только после подключения к сети, добавьте такие зависимости в .service файле:
Также должна быть включена служба ожидания сети того приложения, которое управляет сетью; только тогда network-online.target
будет соответствовать состоянию сети.
Подробнее можно почитать: Network configuration synchronization points.
Если служба отправляет DNS-запросы, она должна запускаться также после :
Подробнее см. .
Чтобы цель работала как положено, должна быть служба, которая запускает её параметром Wants=nss-lookup.target
и размещает себя перед ней (). Обычно это выполняет локальный DNS-распознаватель.
Чтобы узнать, какие службы зависят от , выполните:
$ systemctl list-dependencies --reverse nss-lookup.targetВключение установленных юнитов по умолчанию
Arch Linux поставляется с файлом , в котором указан параметр . Это означает, что systemctl preset отключает по умолчанию юниты и пользователь должен сам их включать после установки пакетов.
Если такое поведение не устраивает, создайте символическую ссылку на для переопределения файла конфигурации. Это заставит systemctl preset включать юниты новых пакетов — вне зависимости от типа — кроме указанных в других файлах из каталога настроек systemctl preset. Пользовательских юнитов это не касается. Подробнее смотрите systemd.preset(5).
Песочница для приложений
Юнит может быть использован в качестве песочницы для изоляции приложений и их процессов в виртуальном окружении. Systemd использует механизм namespaces, белые и чёрные списки capabilities, а также control groups для контейнеризации процессов при помощи настраиваемых окружений — см. .
Добавление к существующему юниту systemd функциональности песочницы обычно происходит методом проб и ошибок вкупе с использованием различных инструментов логирования — strace, stderr и . В таких случаях имеет смысл предварительно поискать соответствующую документацию от разработчиков. В качестве отправной точки для поиска путей повышения безопасности изучите вывод команды:
$ systemd-analyze security юнитРекомендации по созданию песочницы с помощью systemd:
Уведомление о неработающих службах
Для уведомления о неудачном запуске службы используется директива в соответствующем файле службы или drop-in файле. Чтобы эта директива возымела эффект для всех служб одновременно, её необходимо добавть в drop-in файл верхнего уровня, см. .
Создайте drop-in верхнего уровня:
/etc/systemd/system/service.d/toplevel-override.conf
[Unit] OnFailure=failure-notification@%n
Это добавит строку в файл каждой службы. Если какой-то_юнит завершится с ошибкой, запустится экземпляр службы для создания уведомления (или любой другой задачи, которая была назначена).
Создайте юнит-шаблон :
После этого создайте сценарий failure-notification.sh
, в котором определите, каким именно способом будет создаваться уведомление (mail, gotify, xmpp). Параметр будет заменён на название неудачно завершившегося юнита и будет передан сценарию в качестве аргумента.
Чтобы предотвратить регрессию экземпляров , создайте пустой файл drop-in настроек с именем, совпадающим с названием drop-in файла верхнего уровня (пустой файл "уровня служб" будет иметь приоритет над файлом "верхнего уровня"):
# mkdir -p /etc/systemd/system/failure-notification@.service.d # touch /etc/systemd/system/failure-notification@.service.d/toplevel-override.confРешение проблем
Неудачно запущенные службы
Следующая команда найдёт все службы, которые не смогли выполнить запуск:
$ systemctl --state=failedЧтобы определить причину, по которой служба не запустилась, необходимо изучить записи её логов. Подробнее см. systemd/Журнал#Фильтрация вывода.
Диагностика загрузки системы
В systemd есть несколько опций для диагностики проблем процесса загрузки. В статье об отладке загрузки описано, как получить доступ к сообщениям, выданным процессом загрузки до того, как systemd перехватил управление. Также смотрите документацию по отладке systemd.
Диагностика службы
Если какая-либо служба systemd ведет себя не так, как ожидается, и вы хотите получить дополнительную информацию о том, что происходит, присвойте переменной окружения значение . Например, чтобы запустить демон systemd-networkd в режиме отладки:
Добавьте drop-in файл для службы:
[Service] Environment=SYSTEMD_LOG_LEVEL=debugИли, как вариант, пропишите переменную окружения вручную:
# SYSTEMD_LOG_LEVEL=debug /lib/systemd/systemd-networkdПосле этого перезапустите systemd-networkd и следите за журналом службы с помощью опции /.
Выключение/перезагрузка происходят ужасно долго
Если процесс выключения занимает очень долгое время (или выглядит зависшим), то, вероятно, виновата служба, которая не может завершить свою работу. Systemd ожидает некоторое время, пока каждая служба прекратит работу самостоятельно, и только потом пробует завершить её принудительно. Если вы столкнулись с такой проблемой, обратитесь к Shutdown completes eventually в systemd-вики.
По-видимому, процессы с кратким сроком жизни не оставляют записей в логах
Если команда journalctl -u foounit
не даёт вывода для службы с коротким сроком жизни, вместо названия службы используйте её PID. Например, если загрузка службы завершилась неудачно и команда показывает, что она была запущена с PID 123, то вы сможете посмотреть вывод процесса в журнале под данным PID, то есть командой . Поля метаданных для журнала вроде и собираются асинхронно и полагаются на каталог /proc
в случае с действующими процессами. Для решения проблемы требуется внести исправления в ядро, чтобы эти данные можно было собирать через сокет, наподобие . В общем, это баг. Имейте в виду, что быстро падающие службы могут не успеть оставить сообщения в журнале из-за особенностей systemd.
Время загрузки системы увеличивается с течением времени
После использования некоторые пользователи заметили, что время загрузки системы значительно увеличилось. После использования NetworkManager запускался необычно долго.
Проблема связана с тем, что файл стал слишком большим. При этом также может уменьшаться скорость работы других команд, например, systemctl status
или . Для решения проблемы можно удалить все файлы из каталога журнала (в идеале — сделав где-нибудь резервные копии, хотя бы временно), а затем ограничить размер журнала.
systemd-tmpfiles-setup.service не запускается во время загрузки
Начиная с версии Systemd 219, определяет ACL-атрибуты для каталогов в и, следовательно, требует включённой поддержки ACL для той файловой системы, в которой находится журнал.
Отключение emergency mode на удалённой машине
Вам может понадобиться отключить emergency mode на удалённой машине, например на виртуальных машинах Azure или Google Cloud. Это связано с тем, что в случае ухода системы в emergency mode она отключится от сети и лишит вас возможности подключения к ней.
Для отключения этого режима замаскируйте и .