Оглавление |
---|
Информация | ||
---|---|---|
| ||
Накопители информации с твердотельными носителями информации (SSD): особенности применения |
Информация | ||
---|---|---|
| ||
|
Аннотация
Cron
запускается один раз при загрузке системы. Редактирование списка заданий рекомендуется выполнять при помощи команды:Command |
---|
sudo crontab -e |
Справка по командам доступна в
Управление заданиями службы возможно из графического интерфейса через Планировщик задач.
Systemd
оперирует специально оформленными файлами конфигурации— юнитами (unit
). Каждый юнит отвечает за конкретную службу (*.service
), точку монтирования (*.mount
), устройство (*.device
), файл подкачки (*.swap
), сокет (*.socket
) и т. д. Юниты systemd
имеют фиксированный набор параметров, оформленных в виде параметров команды systemctl
(start, stop, reload, restart
и т.д.).
Различия таймеров и заданий cron
Основные причины для применения таймеров вместо заданий cron
:
Информация Для каждого таймера создается отдельный файл журнала
journalctl
Информация |
---|
Создание таймеров
По умолчанию файлы с юнитами , включая юниты с таймерами, распологаются в каталоге
/etc/systemd/system
. Файл с юнитом таймера имеет ссылку на файл с юнитом службы
Информация |
---|
Блок кода | ||
---|---|---|
| ||
[Unit] Description= # имя и описание службы Type=oneshot # тип службы, указан oneshot, без порождения подпроцессов для упрощения взаимодействия с таймерами [Service] Restart=on-failure # перезапуск при сбое, необязательный параметр ExecStart=/usr/local/bin/<имя файла или сценария> # примеры выполняемой команды |
Общая справка доступна по команде man systemd units
. Справка по юнитам служб и параметрам man systemd.service
Управление юнитом службы через таймер
Для запуска юинта службы в файле с юнитом таймера Unit=<имя юнита запускаемой службы>.service
, при этом допускается указание системных служб, перечисленных в
Общая структура юнитов таймеров (таймер запускает юнит службы):
Блок кода | ||
---|---|---|
| ||
[Unit] Description= # имя и краткое описание таймера [Timer] # <Событие запуска таймера> - условие, при котором начинается отсчёт таймера # Ссылка на юнит Unit=<имя юнита запускаемой службы>.service # <=здесь указывается имя юнита службы # Необязательные параметры: Persistent=true # выполнить немедленно после старта системы, если предыдущий запуск был пропущен # по умолчанию установлено false AccuracySec=1h # точность выполнения таймера. # Параметр необходим для снижения нагрузки на ресурсы компьютера при одновременном запуске нескольких таймеров # Таймеры будут запускаться в разные моменты времени в пределах указанного диапазона WakeSystem=30s # интервал, через который будет осуществлен вывод ОС из режима ожидания (suspend) после окончания таймера # Необязательная для таймеров секция [Install] WantedBy=timers.target # WantedBy= — указывает на целевое состояние при котором запускается данный юнит. Целевое состояние определяется статусом загруженной ОС |
Перечень целевых состояний:
Command |
---|
|
Справка доступна по команде man systemd.timer
Событие запуска таймера
Таймеры реального времени
Блок кода | ||
---|---|---|
| ||
.... [Timer] OnCalendar= DayOfWeek Year-Month-Day Hour:Minute:Second # параметр для задания таймера реального времени # вместо DayOfWeek указать Sun, Mon, Tue, Wed, Thu, Fri, Sat . Чтобы таймер выполнялся ежедневно, нужно не указывать значение DayOfWeek или указать на его месте Mon..Sun # вместо указания цифр для Year-Month-Day Hour:Minute:Second можно оставить * # Пример для запуска в каждый вечер пятницы: # OnCalendar= Fri *-*-* 18:00:00 # Пример для запуска каждое 15 число месяца: # OnCalendar= *-*-15 .... |
Справка о формате времени доступна по команде man 7 systemd.time
Монотонные таймеры
Блок кода | ||
---|---|---|
| ||
.... [Timer] <Событие> = <интервал> # Перечень значений параметра <Событие>, с момента которых ведется отсчёт времени, указанный значением <интервал> таймера: # OnActiveSec - старт текущего юнита таймера # OnBootSec - после загрузки ОС # OnStartupSec - после начала сеанса текущего пользователя # OnUnitActiveSec - при старте юнита # OnUnitInactiveSec - при завершении работы юнита # Пример указания <Событие> = <интервал> : # OnActiveSec=50minutes # В указанном примере таймер сработает вновь через 50 минут после собственного запуска .... |
Перед запуском таймера необходимо перезагрузить systemd:
Command |
---|
|
И проверить юниты на наличие синтаксических ошибок:
Command |
---|
|
Запуск таймера:
Command |
---|
|
Информация |
---|
Временное выполнение таймера
Чтобы инициировать таймер, который будет работать только пока существует текущий сеанс, выполнить:
Command |
---|
systemd-run --<событие>="время" --unit="название службы" |
Где:
--<событие>
это одно из событий срабатывания таймера:
--on-active
с момента запуска самого таймера;Раскрыть title Пример Временный таймер, который создает файл
foo
c помощью командыtouch
в каталоге/tmp
через 30 секунд после своего старта:Command Title systemd-run --on-active=30 /bin/touch /tmp/foo Running timer as unit: run-u80.timer
Will run service as unit: run-u80.serviceСодержимое каталога
/tmp
после срабатывания таймера:Блок кода title ls /tmp ... foo
--on-startup
— при запуске ОС;Раскрыть title Пример Временный таймер, который перезапускает службу NetworkManager через 5 минут после запуска ОС:
Command Title systemd-run --on-startup=5m systemctl restart NetworkManager Running timer as unit: run-u80.timer
Will run service as unit: run-u80.service--on-unit-active
— момент запуска указанного юнита;Раскрыть title Пример Временный таймер, который запускается через 2 часа после запуска сценария
Command Title systemd-run --on-unit-active=2h /home/user/script.sh Running timer as unit: run-u80.timer
Will run service as unit: run-u80.service--on-unit-inactive
— при завершении работы юнита;Раскрыть title Пример Временный таймер, который запускается через 2 часа с момента завершения сценария:
Command Title systemd-run --on-unit-inactive=2h /home/user/script.sh Running timer as unit: run-u80.timer
Will run service as unit: run-u80.service--on-calendar
— при наступлении определенного времени (см.Таймеры реального времени).Раскрыть 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 этоидентификатор временного таймера
Где
*:0/1
- время выполнения (каждую минуту) , справка по формату времени см.man systemd.time
Содержимое текстового файла с записями:
Блок кода title ~/log.txt Пн 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 |
---|
|
Где параметр --user
запускает таймер от имени текущего пользователя, а r81fc2842fa884a639d020dea5faabb9d
- идентификатор таймера. Временные таймеры хранятся в каталоге /run/systemd/transient
если заданы без параметра --user
или в /run/user/<идентификатор_пользователя>/systemd/transient
. Идентификатор пользователя доступен по команде id -u
, файлы временных таймеров, хранящихся в указанных каталогах и в качестве имени используют идентификаторы.
Справка см. 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 |
---|
|
Чтобы ограничить вывод записей определенным интервалом, используется параметры -S
и -U (от и до), пример:
Command |
---|
|
Информация |
---|
Следует различать параметры |
или конретным интервалом (пример - день назад):
Command |
---|
|
Справка доступна по команде man
, краткая справка по параметрам - journalctl
journalctl -h
Начиная с очередного обновления 1.7 в Astra Linux Special Edition просмотр журналов юнитов возможен из графического интерфейса через Журнал аудита.