Сравнение версий

Ключ

  • Эта строка добавлена.
  • Эта строка удалена.
  • Изменено форматирование.

Оглавление

Информация
titleДанная статья связана с

Твердотельные накопители (SSD): особенности применения


Информация
titleДанная статья применима к
  • 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 — системная служба, которая запускает в указанное время перечисленные в /etc/crontab команды. Служба запускается один раз при загрузке системы. Редактирование списка заданий рекомендуется выполнять при помощи команды:

Command
sudo crontab -e

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


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= # имя юнита запускаемой службы

# Необязательные параметры:

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Пример создания таймера
Информация

Сценарий необходимо выполнять с правами администратора

Блок кода
titlemake-systemd-timer.sh


Временное выполнение таймера

Чтобы инициировать таймер, который будет работать только пока существует текущий сеанс, выполнить:

Command
sudo systemd-run --<событие>="время" --unit="название службы"

 Где:

--<событие> это одно из событий срабатывания таймера (см Монотонные таймеры): 

  • --on-active

  • --on-startup

  • --on-unit-active

  • --on-unit-inactive

  • --on-calendar

 Справка по systemd-run см. man 1 systemd-run

Управление таймерами

  • получить список всех таймеров, определенных в системе:
    Command

    systemctl list-timers --all

  • получить список активных таймеров:
    Command

    systemctl list-timers

  • получить информацию о статусе конкретного таймера:
    Command

    systemctl status <имя_таймера>.timer

    указание systemctl status *timer выведет информацию обо всех таймерах, определенных в системе.

Пуск, автозапуск, перезапуск, останов, отключение аналогичны командам 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

Просмотр журналов юнитов возможен вместе с журналами других служб из графического интерфейса через Журнал аудита.