| Оглавление |
|---|
| Информация | ||
|---|---|---|
| ||
Накопители информации с твердотельными носителями информации (SSD): особенности применения | ||
| Информация | ||
| ||
|
Аннотация
В настоящей статье описывается работа с таймерами systemd — специальными службы systemd, управляющими запуском других юнитов systemd или программ.
Термины
Общая информация- Cron
— специально оформленный файл конфигурации
Юнит (Якорь unit unit unit)Systemd. Каждый юнит отвечает за
- определенную функциональность:
- службу (
*.service)
- службу (
- ;
- точку монтирования (
*.mount)
- ;
- устройство (
*.device)
- ;
- файл подкачки (
*.swap)
- ;
- сокет (
*.socket); - таймер (
*.timer); - и т. д.
Общие особенности юнитов
- Юниты поддерживают
- выполнение фиксированного набора команд
systemctl(start, stop, reload, restart
- и т.д.).
- Юниты могут запускаться как от имени суперпользователя (общесистемные юниты), так и от имени непривилегированных пользователей (пользовательские юниты).
- По умолчанию пользовательские юниты существуют только в пределах пользовательских сессий, в которой они созданы, если не разрешена их работа вне пользовательской сессии. Разрешить работу пользовательских приложений вне пользовательских
сессий можно командами:
- для текущего пользователя:
Command loginctl enable-linger $USER - для других пользователей:
Command sudo loginctl enable-linger <имя_пользователя>
- для текущего пользователя:
- Для работы с общесистемными юнитами требуются права администратора (используется sudo). Работа с пользовательскими юнитами выполняется с указанием опции --user команды systemctl от имени непривилегированного пользователя
- .
Служба cron
| Раскрыть | ||
|---|---|---|
запускается автоматически при загрузке. Служба поддерживает общесистемные и пользовательские таблицы заданий. Редактирование пользовательского списка заданий рекомендуется выполнять при помощи команды:
Для работы с общесистемной таблицей заданий можно использовать ту же команду от имени суперпользователя (sudo). |
Таймеры
SystemdВ зависимости от принципов запуска существуют два типа таймеровsystemd
Таймеры systemd различаются:
- по принципу запуска:
Информация systemdне связаны с RTOS (real-time operating system)
запускаются в назначенное время,
Оба типа таймеров могут быть:
- Постоянными или временными (существующими в ограниченном отрезке времени).
- Общесистемными или пользовательскими.
- постоянные таймеры;
- временные таймеры:
- временные пользовательские таймеры существуют только в пределах пользовательских сессий, в которой они созданы, если не разрешена их работа вне пользовательской сессии.
| Command |
|---|
| loginctl enable-linger $USER |
| Command |
|---|
| sudo loginctl enable-linger <имя_пользователя> |
- временные общесистемные таймеры существуют до перезагрузки ОС.
Для работы с общесистемными таймерами используется sudo. Работа с пользовательскими таймерами осуществляется без использования sudo от имени непривилегированного пользователя с указанием опции --user в командах systemctl.
Различия таймеров и заданий cron
| Раскрыть | ||
|---|---|---|
Основные причины для применения таймеров вместо заданий
|
Создание таймеров
По умолчанию юниты постоянных системных таймеров располагаются в каталоге /etc/systemd/system. Юниты системных временных таймеров хранятся в каталоге /run/systemd/transient, пользовательских временных таймеров — в каталоге /run/user/<числовой_идентификатор_пользователя>/systemd/transient. Числовой идентификатор пользователя можно получить командой:
| Command |
|---|
| id -u <имя_пользователя> |
Юнит таймера в обязательном порядке содержит ссылку на юнит службы
| Информация |
|---|
Общая структура юнита
службы| Блок кода | ||
|---|---|---|
| ||
[Unit] # Имя и описание службы Description=this is a test example of the service # Тип службы, указан oneshot, без порождения подпроцессов для упрощения взаимодействия с таймерами Type=oneshot [Service] # Перезапуск при сбое, необязательный параметр Restart=on-failure # Пример выполняемой команды ExecStart=/usr/local/bin/<имя файла или сценария> |
Где:
Example.service
- Description
- ExecStart имя исполняемого файла, команды для командной строки, другой службы или сценария.
Общая справка доступна по команде man systemd units. Справка по юнитам служб и параметрам man systemd.service
Управление юнитами службы через таймер
Юнит таймера реального времени
В юните таймера должно быть указано имя юнита, которым управляет таймерДля запуска юнита службы необходимо указать его имя в юните таймера. Unit=<имя_юнита_запускаемой_службы>.service. При этом допускается указание зарезервированных системных служб, перечисленных в
Юнит таймера реального времени
| Блок кода | ||
|---|---|---|
| ||
[Unit] # Имя и краткое описание таймера Description= [Timer] # Пример для запуска в каждый вечер пятницы OnCalendar= Fri *-*-* 18:00:00 # Здесь указывается имя юнита службы Unit=Example.service # Необязательные параметры Persistent=true AccuracySec=1h WakeSystem=30s # Необязательная для таймеров секция [Install] WantedBy=timers.target |
Где:
- Unit Следует различать секцию
[Unit]определяющую параметры юнита таймера и параметрUnit, определяющий юнит службы.service, которым будет управлять таймер. - OnCalendar
Unit
Допускается:Блок кода OnCalendar=ДеньНедели Год-Месяц-День Час:Минута:Секунда
- пропускать неиспользуемые указания времени;
- указывать символ * в значении "каждый";
- для указания интервалов использовать две точки;
- для перечислений использовать запятые;
- для указания отсчёта от окончания периода использовать символ ~ вместо символа -.
Подробная справка о формате времени доступна по команде man 7 systemd.time.
Примеры значений параметра:
| Раскрыть | |||||
|---|---|---|---|---|---|
| |||||
проверить или уточнить формат даты можно командой:
Где Mon..Sun — интересующий момент времени. |
| Информация |
|---|
Для таймеров реального времени допускается указание нескольких параметров |
- Persistent
false. - AccuracySec
- WakeSystem
- WantedBy
timers.target.
Перечень целевых состояний доступен по команде:
| Command |
|---|
|
Справка по настройке таймеров доступна по команде man systemd.timer
Юнит монотонного таймера
[Unit]
# Имя и краткое описание таймера
Description=
[Timer]
# Формат <Событие>=<интервал>. В указанном примере таймер сработает через 50 минут после собственного запуска
OnActiveSec=50minutes
# Здесь указывается имя юнита службы
Unit=Example.service
# Необязательные параметры
Persistent=true
AccuracySec=1h
WakeSystem=30s
# Необязательная для таймеров секция
[Install]
WantedBy=timers.target
Перечень возможных значений параметра <Событие>, с момента которых ведется отсчёт времени таймеромВ юнитах монотонных таймеров указывается событие, от которого начинается отсчет времени срабатывания таймера. Перечень возможных параметров, задающих событие:
- OnBootSec — можно считать, что отсчет времени ведется с момента начала отсчета времени ядром. Контролируемый юнит выполняется однократно. Если при создании таймера указанное время прошло — то контролируемый юнит выполняется немедленно.
- OnStartupSec — отсчет с момента запуска службы systemd. Для системных таймеров параметр близок к параметру OnBootSec, так как системная служба контроля таймеров при загрузке системы стартует как можно раньше. Для пользовательских таймеров отсчет ведется от момента запуска пользовательской службы контроля таймеров, которая запускается при первом входе пользователя. Контролируемый юнит выполняется однократно. Если при создании таймера указанное время прошло — то контролируемый юнит выполняется немедленно.
- OnActiveSec — отсчет от момента активации таймера.
- OnUnitActiveSec — отсчет OnUnitActiveSec — отсчет от старта контролируемого юнита службы. Для начала отсчета юнит службы должен быть запущен принудительно.
- OnUnitInactiveSec — отсчет OnUnitInactiveSec — отсчет от завершения работы отслеживаемого юнита службы. Для начала отсчета юнит службы должен быть запущен принудительно.
- OnClockChange, OnTimezoneChange — при значении
trueсобытием считается изменение показаний системных часов реального времени (CLOCK_REALTIME) относительно показаний монотонных часов (CLOCK_MONOTONIC) или изменение временной зоны.
Перечень значений параметра <интервал> задается указанием временного промежутка (15m — 15 минут, 1h ) подробнее см. man systemd.time
Пример юнита монотонного таймера:
| Блок кода | ||
|---|---|---|
| ||
[Unit]
# Имя и краткое описание таймера
Description=
[Timer]
# Формат <Событие>=<интервал>. В указанном примере таймер сработает через 50 минут после собственного запуска
OnActiveSec=50minutes
# Здесь указывается имя юнита службы
Unit=Example.service
# Необязательные параметры
Persistent=true
AccuracySec=1h
WakeSystem=30s
# Необязательная для таймеров секция
[Install]
WantedBy=timers.target
|
Запуск и отладка таймера
Перед запуском таймера необходимо:
- Перезагрузить конфигурацию служб
systemd:Command sudo systemctl daemon-reload - Проверить юниты на наличие синтаксических ошибок:
Command systemd-analyze verify <имя_юнита>.timer # или .service
- Запустить таймер:
Command sudo systemctl start<имя_таймера>.timer
Временные таймеры
Временные таймеры управляют выполнением заданных команд. Такие таймеры создаются с помощью команды команды systemd-run:.
| Command |
|---|
sudo systemd-run --<событие>="время" --unit="<название_таймера>" <команда> |
При выполнении команды автоматически создаются:
- юнит службы
<название_таймера>.service; - юнит таймера
<название_таймера>.timer.
Опции команды:
--<событие>< событие > — одно из событий срабатывания таймера, . Используются аналоги событий, задаваемых параметрами постоянных таймеров:
-
--on-boot—OnBootSec; --on-activeOnActiveSec;--on-startup—OnStartupSec;--on-unit-active—OnUnitActiveSec;--on-unit-inactive—OnUnitInactiveSec;--on-calendar—OnCalendar.
Пример:
| Раскрыть | ||||||||||
|---|---|---|---|---|---|---|---|---|---|---|
| ||||||||||
Временный таймер, который каждую минуту выполняет команду "
Где Содержимое текстового файла с записями:
|
Принудительный останов временного таймера:
| Command |
|---|
|
Управление таймерами
- получить список всех системных таймеров, определенных в системе:
Command systemctl list-timers --all - получить список активных системных таймеров:
Command systemctl list-timers - получить информацию о статусе конкретного системного таймера:
Command systemctl status <имя_таймера>.timerуказание
systemctl status *timerвыведет информацию обо всех таймерах, определенных в системе.
Для получения информации и пользовательских таймерах следует использовать опцию --user.
Пуск, автозапуск, перезапуск, останов, отключение аналогичны командам systemctl для служб. Справка доступна по команде man systemctl, краткая по systemctl -h
Просмотр журналов юнитов
Посмотреть записи журнала конкретного юнита:
| Command |
|---|
|
Чтобы ограничить вывод записей определенным интервалом, используется параметры -S и -U (от и до), пример:
| Command |
|---|
|
| Информация |
|---|
Следует различать параметры |
или конкретным интервалом (пример - день назад):
| Command |
|---|
|
Справка доступна по команде man , краткая справка по параметрам - journalctl journalctl -h
Начиная с очередного обновления 1.7 в Astra Linux Special Edition просмотр журналов юнитов возможен из графического интерфейса через Журнал аудита.