Аннотация
Cron — системная служба, которая запускает в указанное время перечисленные в /etc/crontab
команды. Служба запускается один раз при загрузке системы. Редактирование списка заданий рекомендуется выполнять при помощи команды:
Управление заданиями службы возможно из графического интерфейса через Планировщик задач.
Systemd — системная служба, которая обеспечивает параллельный запуск других служб в процессе загрузки ОС. Systemd
оперирует специально оформленными файлами конфигурации— юнитами (unit
). Каждый юнит отвечает за конкретную службу (*.service
), точку монтирования (*.mount
), устройство (*.device
), файл подкачки (*.swap
), сокет (*.socket
) и т. д. Юниты systemd
имеют фиксированный набор параметров, оформленных в виде параметров команды systemctl
(start, stop, reload, restart
и т.д.).
Таймер systemd (далее просто таймер) — файлы юнитов systemd
, имя которых имеет расширение (*.timer
); они позволяют контролировать файлы служб (*.service
).
В зависимости от принципов запуска существуют три типа таймеров:
- таймеры реального времени, срабатывающие с привязкой к системному календарю. Аналогичны инструменту
cron
, но обладают более гибкими настройками периодов работы;
- монотонные таймеры запускающиеся в назначенное время, прошедшее с определенной начальной точки. Не сработают, если комптютер в режиме ожидания.
Различия таймеров и заданий cron
Основные причины для применения таймеров вместо заданий cron
:
- таймеры используют единую систему команд инструмента управления службами
systemctl
; - таймеры имеют встроенные функции для ведения журналов и отслеживания состояния выполнения;
Информация |
---|
Для каждого таймера создается отдельный файл журнала journalctl |
- таймеры могут инициировать выполнение задач на основе событий системы, например запуска или окончания работы службы, вызванной другим таймером, а не только по расписанию как
cron
;
- приоритет выполнения таймеров выше, чем у заданий
cron
;
systemd
предотвращает возникновение работающих юнитов-дублей;- задания
cron
выполняются последовательно, если заданиям cron
назначен одинаковый интервал выполнениия первым выполнится требующее меньшего времени на выполнение. Таймеры могут работать совместно как службы.
Создание таймеров
По умолчанию файлы с юнитами systemd
, включая юниты с таймерами, распологаются в каталоге /etc/systemd/system
. Файл с юнитом таймера (*.timer
) имеет ссылку на файл с юнитом службы (*.service
), которую он контролирует.
Systemd
имеет несколько зарезервированных системных юнитов, перечень которых доступен по команде man systemd.special
. Использование имён юнитов из перечня системных нежелательно и приводит к ошибке выполнения создаваемого юнита.
Общая структура юнитов служб:
Блок кода |
---|
title | /etc/systemd/system/<Служба>.service |
---|
|
[Unit]
Description= # имя и описание службы
Type=oneshot # тип службы, указан oneshot, без порождения подпроцессов для упрощения взаимодействия с таймерами
[Service]
ExecStart=/usr/local/bin/<имя файла или сценария> # примеры выполняемой команды |
Справка доступна по команде man systemd.units
Общая структура юнитов таймеров:
Блок кода |
---|
title | /etc/systemd/system/<Таймер>.timer |
---|
|
[Unit]
Description= # имя и краткое описание таймера
[Timer]
<Событие срабатывания таймера>
Unit=<Служба>.service
Unit=<имя юнита запускаемой службы>
# Необязательные параметры:
Persistent=true # выполнить немедленно после старта системы, если предыдущий запуск был пропущен
AccuracySec=1h # точность выполнения таймера.
# Параметр необходим для снижения нагрузки на ресурсы компьютера при одновременном запуске нескольких таймеров
# Таймеры будут запускаться в разные моменты времени в пределах указанного диапазона
WakeSystem=30s # интервал, через который будет осуществлен вывод ОС из режима ожидания (suspend) после окончания таймера
# Необязательная для таймеров секция
[Install]
WantedBy=timers.target
# WantedBy= — указывает на целевое состояние при котором запускается данный юнит. Целевое состояние определяется статусом загруженной ОС - |
Перечегь целевых состояний:
Command |
---|
systemctl list-unit-files --type=target
|
Справка доступна по команде man systemd.timer
Событие срабатывания таймера
Таймеры реального времени
Блок кода |
---|
title | /etc/systemd/system/<РеалВрТаймер>.timer |
---|
|
....
[Timer]
OnCalendar= DayOfWeek Year-Month-Day Hour:Minute:Second # параметр для задания таймера реального времени
# вместо DayOfWeek указать Sun, Mon, Tue, Wed, Thu, Fri, Sat . Чтобы таймер выполнялся ежедневно, нужно не указывать параметр или указать Mon..Sun
# вместо указания цифр для Year-Month-Day Hour:Minute:Second можно оставить *
# Пример для запуска в каждый вечер пятницы:
# OnCalendar= Fri *-*-* 18:00:00
# справка о формате времени - man 7 systemd.time
.... |
Монотонные таймеры
Блок кода |
---|
title | /etc/systemd/system/<МоноТаймер>.timer |
---|
|
....
[Timer]
<Событие> = <интервал>
# Перечень событий:
# OnActiveSec - старт текущего юнита таймера
# OnBootSec - после загрузки ОС
# OnStartupSec - после начала сеанса текущего пользователя
# OnUnitActiveSec - при старте юнита службы
# OnUnitInactiveSec - при завершении работы юнита службы
# Пример:
# OnActiveSec=50minutes
....
|
Перед запуском таймера необходимо перезагрузить systemd:
Command |
---|
systemctl daemon-reload
|
И проверить юниты на наличие синтаксических ошибок:
Command |
---|
systemd-analyze verify
|
Запуск таймера:
Command |
---|
systemctl start <имя_таймера>
|
Раскрыть |
---|
title | Пример создания таймера |
---|
|
Информация |
---|
Сценарий необходимо выполнять с правами администратора |
Блок кода |
---|
title | make-systemd-timer.sh |
---|
| |
|
Временное выполнение таймера
Чтобы инициировать таймер, который будет работать только пока существует текущий сеанс, выполнить:
Command |
---|
sudo systemd-run --<событие>="время" --unit="название службы"
|
Где:
--<событие>
это одно из событий срабатывания таймера (см Монотонные таймеры):
--on-active
--on-startup
--on-unit-active
--on-unit-inactive
--on-calendar
Справка по Останов временного таймера: Command |
---|
systemctl --user stop run-<идентификатор_временного_таймера>.timer
|
Раскрыть |
---|
title | Пример временного таймера |
---|
|
Временный таймер, который делает запись в текстовый файл каждую минуту: Command |
---|
Title | systemd-run --user --on-calendar '*:0/1' /bin/sh -c "date >> ~/log.txt" |
---|
| Running timer as unit: run-r81fc2842fa884a639d020dea5faabb9d.timer Will run service as unit: run-r81fc2842fa884a639d020dea5faabb9d.service # последовательность r81fc2842fa884a639d020dea5faabb9d это идентификатор временного таймера
|
Содержимое файла: Блок кода |
---|
| Пн 11 ноя 2024 10:03:00 MSK
Пн 11 ноя 2024 10:04:00 MSK
Пн 11 ноя 2024 10:05:00 MSK
Пн 11 ноя 2024 10:06:00 MSK
Пн 11 ноя 2024 10:07:00 MSK
Пн 11 ноя 2024 10:08:00 MSK
Пн 11 ноя 2024 10:09:00 MSK
Пн 11 ноя 2024 10:10:00 MSK |
Останов временного таймера: Command |
---|
systemctl --user stop run-r81fc2842fa884a639d020dea5faabb9d.timer
|
|
Справка по systemd-run
см. man 1 systemd-run
Управление таймерами
Пуск, автозапуск, перезапуск, останов, отключение аналогичны командам systemctl
для служб. Справка доступна по команде man systemctl
, краткая по systemctl -h
Просмотр журналов юнитов
Посмотреть записи журнала конкретного юнита:
Command |
---|
sudo journalctl -b -u <имя_юнита> # .service или .timer, параметр -b ограничивает вывод записей текущей загрузкой
|
Чтобы ограничить вывод записей определенным интервалом, используется параметры -S
и -U (от и до), пример:
Command |
---|
sudo journalctl -S "2024-11-03 07:00:00" -U "2024-11-07 07:15:00" -u anacron.timer # имя юнита для примера
|
Информация |
---|
Anacron это вспомогательный инструмент cron для запуска пропущенных cron во время отключения компьютера заданий. Anacron использует таймеры systemd . Следует различать параметры -u (юнит) и -U (до) инструмента |
или конретным интервалом (пример - день назад):
Command |
---|
sudo journalctl -S -1d -u anacron.timer
|
Справка для journalctl
доступна по команде man journalctl
, краткая справка по параметрам - journalctl -h
Начиная с очередного обновления 1.7 в Astra Linux Special Edition просмотр журналов юнитов возможен из графического интерфейса через Журнал аудита.