Данная статья связана с
Данная статья применима к
- Astra Linux Special Edition РУСБ.10015-01 (очередное обновление 1.8)
- Astra Linux Special Edition РУСБ.10015-01 (очередное обновление 1.7)
- Astra Linux Special Edition РУСБ.10152-02 (очередное обновление 4.7)
- Astra Linux Special Edition РУСБ.10015-01 (очередное обновление 1.6)
- Astra Linux Special Edition РУСБ.10015-16 исп. 1 и исп. 2
- Astra Linux Special Edition РУСБ.10015-01 (очередное обновление 1.5)
- Astra Linux Special Edition РУСБ.10265-01 (очередное обновление 8.1)
- Astra Linux Common Edition 2.12
Аннотация
Cron
запускается один раз при загрузке системы. Редактирование списка заданий рекомендуется выполнять при помощи команды:sudo crontab -e
Справка по командам доступна в
Управление заданиями службы возможно из графического интерфейса через Планировщик задач.
Systemd
оперирует специально оформленными файлами конфигурации— юнитами (unit
). Каждый юнит отвечает за конкретную службу (*.service
), точку монтирования (*.mount
), устройство (*.device
), файл подкачки (*.swap
), сокет (*.socket
) и т. д. Юниты systemd
имеют фиксированный набор параметров, оформленных в виде параметров команды systemctl
(start, stop, reload, restart
и т.д.).
systemd
не связаны с RTOS (real-time operating system)
оба типа таймеров могут запускаться временно и существовать, пока существует пользовательская сессия, из которой они были запущены.
Различия таймеров и заданий cron
Основные причины для применения таймеров вместо заданий cron
:
Для каждого таймера создается отдельный файл журнала
journalctl
Создание таймеров
По умолчанию файлы с юнитами , включая юниты с монотонными таймерами и таймерами реального времени распологаются в каталоге
/etc/systemd/system
. Временные таймеры хранятся в каталоге /run/systemd/transient
если заданы без параметра --user
или в /run/user/<идентификатор_пользователя>/systemd/transient
если параметр был указан. Идентификатор пользователя доступен по команде 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
Где:
- Description
- Unit
.service
Следует различать секцию
[Unit]
определяющую юнит таймера и параметрUnit
, определяющий юнит службы.service
, которым будет управлять таймер OnCalendar
Unit
Общий формат :OnCalendar=DayOfWeek Year-Month-Day Hour:Minute:Second.
Допускается опускать какой либо из промежутков времени указывая вместо них*
.Для таймеров реального времени допускается указание нескольких параметров
OnCalendar
с разными интервалами времени и моментами срабатывания- Persistent
false
- AccuracySec
- WakeSystem
- WantedBy
timers.target
Перечень целевых состояний доступен по команде:
systemctl list-unit-files --type=target
Справка по конфигурированию таймеров доступна по команде man systemd.timer
[Unit] # Имя и краткое описание таймера Description= [Timer] # Формат <Событие>=<интервал>. В указанном примере таймер вновь через 50 минут после собственного запуска OnActiveSec=50minutes # Здесь указывается имя юнита службы Unit=Example.service # Необязательные параметры Persistent=true AccuracySec=1h WakeSystem=30s # Необязательная для таймеров секция [Install] WantedBy=timers.target
Где:
Перечень значений параметра <Событие>
, с момента которых ведется отсчёт времени таймером:
- OnStartupSec
systemd
; после успешного запуска службы - OnBootSec момента начала отсчета времени ядром; с
- OnActiveSec старт текущего юнита таймера;
- OnUnitActiveSec при старте отслеживаемого юнита службы;
- OnUnitInactiveSec при завершении работы отслеживаемого юнита службы.
перечень значений параметра <интервал>
задается указанием временного промежутка (15m
— 15 минут, 1h
) подробнее см. man systemd.time
Запуск и отладка таймера
Перед запуском таймера необходимо перезагрузить systemd:
sudo systemctl daemon-reload
И проверить юниты на наличие синтаксических ошибок:
systemd-analyze verify <имя_юнита>.timer # или .service
Запуск таймера:
sudo systemctl start
<имя_таймера>.timer
Временное выполнение таймера
Чтобы инициировать таймер, который будет работать только пока существует породившая его пользовательская сессия используются временные таймеры. Временный таймер самостоятельно создает юнит службы .service
c идентификатором временного таймера в качестве названия. Юнит службы временного таймера содержит указанные при запуске через systemd-run
параметры. Временные таймеры и связанные службы исчезают после завершения сеанса пользователя
Временные таймеры создаются через systemd-run
:
sudo systemd-run --<событие>="время" --unit="название службы"
Где:
--<событие>
это одно из событий срабатывания таймера, аналоги событий:
--on-boot
—OnBootSec;
--on-active
OnActiveSec
;--on-startup
—OnStartupSec
;--on-unit-active
—OnUnitActiveSec
;--on-unit-inactive
—OnUnitInactiveSec
;--on-calendar
—OnCalendar
.
Принудительный останов временного таймера:
sudo systemctl --user stop run-r81fc2842fa884a639d020dea5faabb9d.timer
Где параметр --user
запускает таймер от имени текущего пользователя, а r81fc2842fa884a639d020dea5faabb9d
- идентификатор таймера. Справка см. man 1 systemd-run
Управление таймерами
- получить список всех таймеров, определенных в системе:
systemctl list-timers --all
- получить список активных таймеров:
systemctl list-timers
- получить информацию о статусе конкретного таймера:
systemctl status <имя_таймера>.timer
указание
systemctl status *timer
выведет информацию обо всех таймерах, определенных в системе.
Пуск, автозапуск, перезапуск, останов, отключение аналогичны командам systemctl
для служб. Справка доступна по команде man systemctl
, краткая по systemctl -h
Просмотр журналов юнитов
Посмотреть записи журнала конкретного юнита:
sudo journalctl -b -u
<имя_юнита> # .service или .timer, параметр -b ограничивает вывод записей текущей загрузкой
Чтобы ограничить вывод записей определенным интервалом, используется параметры -S
и -U (от и до), пример:
sudo journalctl -S
"2024-11-03 07:00:00"
-U
"2024-11-07 07:15:00" -u anacron.timer # имя юнита для примера
Anacron
это вспомогательный инструмент cron
для запуска пропущенных cron
во время отключения компьютера заданий.
Следует различать параметры -u
(юнит) и -U
(до)
или конретным интервалом (пример - день назад):
sudo journalctl -S
-1d
-u anacron.timer
Справка доступна по команде man
, краткая справка по параметрам - journalctl
journalctl -h
Начиная с очередного обновления 1.7 в Astra Linux Special Edition просмотр журналов юнитов возможен из графического интерфейса через Журнал аудита.