Введение

Cron — это хронологический демон-планировщик задач, работающий в операционных системах типа Unix, включая дистрибутивы Linux. Cron запускается в фоновом режиме, а задачи, запланированные в cron и именуемые «задачи cron», выполняются автоматически, что делает cron полезным для автоматизации связанных с обслуживанием задач.

В этом обучающем руководстве вы познакомитесь с тем, как планировать задачи с помощью специального синтаксиса cron. Также мы рассмотрим несколько комбинаций клавиш, которые вы можете использовать при создании расписаний задач, чтобы их проще было писать и понимать.

Предварительные требования

Для выполнения этого обучающего руководства вам потребуется доступ к компьютеру с Ubuntu 18.04. Это может быть ваш локальный компьютер, виртуальная машина или виртуальный приватный сервер.

Независимо от того, какой компьютер вы используете для выполнения этого обучающего руководства, у вас должен быть пользователь без привилегий root с настроенными правами администратора. Чтобы выполнить настройку, воспользуйтесь руководством по начальной настройке сервера Ubuntu 18.04.

Установка cron

Почти все дистрибутивы Linux имеют ту или иную форму cron, установленную по умолчанию. Но если вы используете компьютер Ubuntu, где cron не установлен, вы можете установить его с помощью APT.

Перед установкой cron на компьютер Ubuntu обновите локальный индекс пакетов компьютера:

  1. sudo apt update

Затем выполните установку cron с помощью следующей команды:

  1. sudo apt install cron

Вам также нужно убедиться, что он настроен для работы в фоновом режиме:

  1. sudo systemctl enable cron
Output
Synchronizing state of cron.service with SysV service script with /lib/systemd/systemd-sysv-install. Executing: /lib/systemd/systemd-sysv-install enable cron

После этого cron будет установлен в системе, а вы сможете начать составлять расписание задач.

Как работает Cron

Задачи в cron записываются и управляются в специальном файле crontab. Каждый профиль пользователя в системе может иметь собственный файл crontab, где составляются расписания задач, которые хранятся в /var/spool/cron/crontabs/.

Чтобы запланировать задачу, вам нужно открыть ваш файл crontab для редактирования и добавления задачи, написанной в форме выражения cron. Синтаксис выражений cron можно разбить на два элемента: расписание и команда для запуска.

Команда может быть практически любой командой, которую вы можете запустить в командной строке. Компонент расписания в синтаксисе разбит на 5 разных полей, которые расположены в следующем порядке:

Поле Допустимые значения
минута 0–59
час 0–23
День месяца 1–31
месяц 1–12 или ЯНВ–ДЕК
День недели 0–6 или ПНД–ВСК

Все вместе задачи, запланированные в crontab, выглядят следующим образом:

minute hour day_of_month month day_of_week command_to_run

Ниже представлен функциональный пример выражения cron. Это выражение запускает команду curl http://www.google.com каждый вторник в 17:30:

30 17 * * 2 curl http://www.google.com

Также существует несколько специальных символов, которые вы можете включить в компонент расписания выражения cron, что упрощает создание расписания:

Примечание. Вы не можете выражать значения шага произвольно, допускается использование только целых чисел, которые равномерно делят диапазон, допустимый для данного поля. Например, в поле «часы» вы можете указать после косой черты только 1, 2, 3, 4, 6, 8 или 12.

Ниже представлено несколько примеров использования компонента расписания cron:

Если вы найдете что-то из этого затруднительным или вам потребуется помощь при написании расписания для ваших собственных задач cron, Cronitor предоставляет удобный редактор выражений cron, который называется Crontab Guru и который вы можете использовать для проверки действительности ваших расписаний cron.

Управление файлами crontab

После настройки расписания и определения задания, которое нужно запустить, вам нужно будет поместить его в место, где ваш демон сможет его прочитать.

Как уже упоминалось выше, crontab — это специальный файл, где содержится расписание задач, которые cron будет запускать. Однако эти данные не предназначены для редактирования напрямую. Вместо этого рекомендуется использовать команду crontab. Она позволяет изменять файл crontab вашего профиля без внесения изменений в ваши права с помощью sudo. Команда crontab также позволит вам понять, есть ли в crontab ошибки синтаксиса, независимо от того, редактируете вы его или нет.

Вы можете изменить файл crontab с помощью следующей команды:

  1. crontab -e

Если вы впервые запускаете команду crontab в этом профиле пользователя, вы сможете выбрать используемый по умолчанию текстовый редактор для использования при редактировании crontab:

Output
no crontab for sammy - using an empty one Select an editor. To change later, run 'select-editor'. 1. /bin/nano <---- easiest 2. /usr/bin/vim.basic 3. /usr/bin/vim.tiny 4. /bin/ed Choose 1-4 [1]:

Введите число, соответствующее нужному вам редактору. Кроме того, вы можете просто нажать ENTER, чтобы использовать вариант по умолчанию, nano.

После выбора вы попадете в новый файл crontab, содержащий ряд закомментированных инструкций по его использованию:

# Edit this file to introduce tasks to be run by cron.
#
# Each task to run has to be defined through a single line
# indicating with different fields when the task will be run
# and what command to run for the task
#
# To define the time you can provide concrete values for
# minute (m), hour (h), day of month (dom), month (mon),
# and day of week (dow) or use '*' in these fields (for 'any').#
# Notice that tasks will be started based on the cron's system
# daemon's notion of time and timezones.
#
# Output of the crontab jobs (including errors) is sent through
# email to the user the crontab file belongs to (unless redirected).
#
# For example, you can run a backup of all your user accounts
# at 5 a.m every week with:
# 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
#
# For more information see the manual pages of crontab(5) and cron(8)
#
# m h  dom mon dow   command

При запуске crontab -e в следующий раз, ваш файл будет автоматически открываться в этом текстовом редакторе. После входа в редактор вы можете ввести свое расписание для каждой задачи в новой строке. В противном случае вы можете сохранить изменения и закрыть файл crontab (CTRL + X, Y, а затем ENTER, если вы выбрали nano).

Примечание. В системах Linux имеется другой файл crontab, сохраненный в директории /etc/. Это системный файл crontab, где имеется дополнительное поле, определяющее, для какого профиля пользователя должна запускаться каждая команда cron. В этом обучающем руководстве мы будем использовать файл crontab для конкретного пользователя, но если вы хотите изменить системный файл crontab, вы можете сделать это с помощью следующей команды:

  1. sudo nano /etc/crontab

Если вы хотите просмотреть содержимое файла crontab, не изменяя его, вы можете использовать следующую команду:

  1. crontab -l

Вы можете стереть файл crontab с помощью следующей команды:

Предупреждение. Следующая команда не будет запрашивать подтверждение того, что вы хотите стереть ваш файл crontab. Используйте ее, если вы уверены, что хотите стереть его.

  1. crontab -r

Эта команда удаляет файл crontab пользователя немедленно. Однако вы можете включить флаг -i, чтобы добавить в команду подтверждение того, что вы действительно хотите удалить пользовательский файл crontab:

  1. crontab -r -i
Output
crontab: really delete sammy's crontab? (y/n)

После получения запроса вы должны ввести y, чтобы удалить файл crontab, или n, чтобы отменить удаление.

Управление выводом задачи cron

Поскольку задачи cron выполняются в фоновом режиме, не всегда очевидно, что они были запущены успешно. Теперь, когда вы знаете, как использовать команду crontab и как запланировать задачу cron, вы можете начать экспериментировать с различными способами перенаправления результатов выполнения задач cron, чтобы помочь вам отследить их успешное выполнение.

Если у вас есть агент передачи почты, например, Sendmail, который установлен и настроен на сервере, вы можете отправить результат выполнения задачи cron на электронный адрес, связанный с вашим профилем пользователя Linux. Также вы можете вручную задать адрес электронной почты, указав параметр MAILTO вверху crontab.

Например, вы можете добавить следующие строки в файл crontab. К ним относятся оператор MAILTO, за которым следует пример адреса электронной почты, директива SHELL, которая указывает оболочку для запуска (в данном примере bash), директива HOME, указывающая путь поиска бинарного файла cron, и единственная задача cron:

. . .

MAILTO="example@digitalocean.com"
SHELL=/bin/bash
HOME=/

* * * * * echo ‘Run this command every minute’

Эта конкретная задача будет возвращать «Run this command every minute», а этот вывод будет отправляться каждую минуту на адрес электронной почты, заданный директивой MAILTO.

Также вы можете перенаправить вывод задачи cron в файл журнала или в пустую директорию, чтобы не получать электронное сообщение с выводом.

Чтобы добавить вывод запланированной команды в файл журнала, добавьте >> в конец команды, после чего укажите имя и расположение файла журнала, как показано здесь:

* * * * * echo ‘Run this command every minute’ >> /directory/path/file.log

Скажем, что мы хотим использовать cron для запуска скрипта, но скрипт при этом должен выполняться в фоновом режиме. Для этого вы можете перенаправить вывод скрипта в пустую директорию, например /dev/null, которая немедленно удаляет все данные, добавляемые в нее. Например, следующая команда cron выполняет скрипт PHP и запускает его в фоновом режиме:

* * * * * /usr/bin/php /var/www/domain.com/backup.php > /dev/null 2>&1

Эта задача cron также перенаправляет стандартную ошибку — представляемую как 2 — в стандартный вывод (>&1). Поскольку стандартный вывод уже перенаправляется в директорию /dev/null, это позволяет запускать скрипт без лишнего шума. Даже если в crontab содержится оператор MAILTO, вывод команды не будет отправляться на заданный адрес электронной почты.

Ограничение доступа

Вы можете управлять тем, каким пользователям разрешается использовать команду crontab, с помощью файлов cron.allow и cron.deny, которые хранятся в директории /etc/. Если файл cron.deny существует, любой пользователь, который будет указан в нем, не будет иметь возможность менять файл crontab. Если cron.allow существует, то только пользователи, указанные в нем, будут иметь возможность изменять файлы crontab. Если оба файла существуют, и пользователь указан в каждом файле, файл cron.allow будет иметь приоритет над cron.deny, и этот пользователь сможет изменять файл crontab.

Например, чтобы запретить доступ для всех пользователей, а затем предоставить доступ пользователю ishmael, вы можете использовать следующую последовательность команд:

  1. sudo echo ALL >>/etc/cron.deny
  2. sudo echo ishmael >>/etc/cron.allow

Сначала мы закрываем доступ для всех пользователей, добавив ALL в файл cron.deny. Затем, добавив имя пользователя в файл cron.allow, мы предоставим пользователю ishmael доступ к выполнению задач cron.

Обратите внимание, что если пользователь имеет права sudo, он может изменять файл crontab другого пользователя с помощью следующей команды:

  1. sudo crontab -u user -e

Однако, если cron.deny существует, и user добавлен в него, но не указан в файле cron.allow, вы получите следующую ошибку после запуска предыдущей команды:

Output
The user user cannot use this program (crontab)

По умолчанию большинство демонов cron полагает, что все пользователи имеют доступ к cron, если только не существует cron.allow или cron.deny.

Специальный синтаксис

Существует также несколько коротких команд, которые вы можете использовать в файле crontab, чтобы упростить процесс создания расписания задач. Они являются эквивалентом для указанных примеров числового расписания:

Сокращение Краткая запись для
@hourly 0 * * * *
@daily 0 0 * * *
@weekly 0 0 * * 0
@monthly 0 0 1 * *
@yearly 0 0 1 1 *

Примечание. Не все демоны cron могут понимать этот синтаксис (в частности, более ранние версии), поэтому рекомендуем убедиться в этом, прежде чем широко использовать подобный синтаксис.

Кроме того, краткая запись @reboot будет запускать любую команду, которая следует за ней при каждом запуске сервера:

@reboot echo "System start up"

Использование этих комбинаций при возможности поможет понимать расписание задач в вашем файле crontab.

cron

cron
Содержание
cron
Листинг
Основные настройки
Не обязательные настройки
Выбор времени выполнения задания
Дополнительные переменные cron
Управление при помощи crontab
Примеры
GUI версии
GTK+
KDE
Ссылки


cron – программа-демон, предназначенная для выполнения заданий в определенное время, или через определенные промежутки времени. Для редактирования заданий используется утилита crontab.


Листинг
Нельзя изменять файл расписания, просто открыв его в текстовом редакторе. Для его редактирования необходимо использовать команду crontab -e.
Простой пример файла расписания. Создание снимка экрана каждый час:
SHELL=/bin/bash
MAILTO=username
0 * * * * scrot
Основные настройки
Выбор среды для исполняемых задач:
SHELL=/bin/bash Имя пользователя, которому будет послано сообщение о выполнении задания:
MAILTO=username
Вместо имени, также можно использовать электронный адрес:
MAILTO=example@example.org
Не обязательные настройки Задаем каталог пользователя: HOME=


Задаем каталоги исполняемых фалов:


PATH=/sbin:/bin:/usr/sbin:/usr/bin
Прописываем дисплей, если запускаемый по крону скрипт должен использовать графику:
DISPLAY=:0.0 Выбор времени выполнения задания
Время запуска представляется в таком виде: минута час день_месяца месяц день_недели команда
Значение
Диапазон
Дополнительно минуты
0-59
часы
0-23
дни месяца
1-31
месяцы
1-12
можно задавать и в 3-х буквенном варианте
дни недели
0-6 можно задавать и в 3-х буквенном варианте (0=воскресенье)
Символ '*' подразумевает - любое значение.
Минимальное время 1-а минута. Это связано с тем что cron каждую минуту просматривает список заданий, и ищет которые нужно выполнить.
Дни недели и месяца в трех буквенном варианте: sun mon tue wed thu fri sat jan feb mar apr may jun jul aug sep oct nov dec


Дополнительные переменные cron

Переменная Описание Эквивалент @reboot Запуск при загрузке
@yearly Раз в год 0 0 1 1 *
@annually Тоже что и @yearly
@monthly Раз в месяц 0 0 1 * *
@weekly Раз в неделю 0 0 * * 0
@daily Раз в день 0 0 * * *
@midnight В полночь (00:00)
@hourly Каждый час 0 * * * *

Управление при помощи crontab

Добавление файла расписания: crontab имя_файла_расписания Вывести содержимое текущего файла расписания: crontab -l Удаление текущего файла расписания: crontab -r

Редактирование текущего файла расписания (при первом запуске будет выведен список поддерживаемых текстовых редакторов):

crontab -e Этот ключ позволяет выполнять вышеописанные действия для конкретного пользователя: crontab -u username Учтите, что -u можно воспользоваться только запуская crontab от лица суперпользователя. Примеры Каждую минуту: * * * * * Каждый час, с использованием переменных cron: @hourly ~/script.sh Каждый день в 03:15 запускать скрипт: 15 3 * * * ~/script.sh Каждый понедельник: 0 0 * * 1 Каждый четный час: * */2 * * * Тоже что и выше, но расписанное полностью: * 0,2,4,6,8,10,12,14,16,18,20,22 * * * Каждые 10 минут: */10 * * * * Новый год : 59 23 31 dec * Каждый будний день в 22:00: 0 22 * * 1-5 Запуск программы с графической оболочкой (GUI); каждую минуту будет отображаться сообщение с текстом «It work!»: 0-59 * * * * DISPLAY=:0 gdialog --msgbox "It work\!" 25 20 > /dev/null * где DISPLAY=:0 - номер монитора GUI версии GTK+

Есть очень полезная программа: Scheduled tasks(gnome-schedule). Она представляет собой графический интерфейс для cron, и будет полезна новичкам, так как понятным языком описывает время выполнения задачи. К примеру:

15 * * * * каждый час в 15 минут; * 0 * * * каждую минуту, между 00:00 и 00:59. KDE Для KDE существует Task Scheduler, который встраивается в окно настройки системы. Ссылкиcron Содержание cron Листинг Основные настройки Не обязательные настройки Выбор времени выполнения задания Дополнительные переменные cron Управление при помощи crontab Примеры GUI версии GTK+ KDE Ссылки