Оглавление |
---|
Информация | ||
---|---|---|
| ||
Накопители информации с твердотельными носителями информации (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] ExecStart=/usr/local/bin/<имя файла или сценария> # примеры выполняемой команды |
Справка доступна по команде man systemd.units
Общая структура юнитов таймеров:
Блок кода | ||
---|---|---|
| ||
[Unit] Description= # имя и краткое описание таймера [Timer] # <Событие срабатывания таймера> - условие, при котором начинается отсчёт таймера # Ссылка на юнит Unit=<имя юнита запускаемой службы>.service # Необязательные параметры: Persistent=true # выполнить немедленно после старта системы, если предыдущий запуск был пропущен 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 .... |
Справка о формате времени доступна по команде man 7 systemd.time
Монотонные таймеры
Блок кода | ||
---|---|---|
| ||
.... [Timer] <Событие> = <интервал> # Перечень значений параметра <Событие>, с момента которых ведется отсчёт времени, указанный значением <интервал> таймера: # OnActiveSec - старт текущего юнита таймера # OnBootSec - после загрузки ОС # OnStartupSec - после начала сеанса текущего пользователя # OnUnitActiveSec - при старте юнита # OnUnitInactiveSec - при завершении работы юнита # Пример указания <Событие> = <интервал> : # OnActiveSec=50minutes # В указанном примере таймер сработает вновь через 50 минут после собственного запуска .... |
Перед запуском таймера необходимо перезагрузить systemd:
Command |
---|
|
И проверить юниты на наличие синтаксических ошибок:
Command |
---|
|
Запуск таймера:
Command |
---|
|
Раскрыть | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
| ||||||||||||
Проверка тестового таймера:
|
Информация |
---|
Временное выполнение таймера
Чтобы инициировать таймер, который будет работать только пока существует текущий сеанс, выполнить:
Command |
---|
systemd-run --<событие>="время" --unit="название службы" |
Где:
--<событие>
это одно из событий срабатывания таймера:
--on-active
с момента запуска самого таймера;--on-startup
— при запуске ОС;--on-unit-active
— момент запуска юнита;--on-unit-inactive
— при завершении работы юнита;--on-calendar
— при наступлении определенного времени (см.Таймеры реального времени).
Останов временного таймера:
Command |
---|
|
Где параметр --user
запускает таймер от имени текущего пользователя.
Раскрыть | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
| ||||||||||||
Временный таймер, который делает запись в текстовый файл каждую минуту:
Содержимое файла:
Останов временного таймера:
|
Временные таймеры хранятся в каталоге /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 просмотр журналов юнитов возможен из графического интерфейса через Журнал аудита.