Cron-формат

Cron-формат это простой, но мощный и гибкий способ описания времени и периодичности действий. nnCron LITE использует cron-формат при указании временных интервалов в кронтабе.

Традиционный (унаследлванный из мира Unix) cron-формат состоит из пяти полей, разделенных пробелами:

<Минуты> <Часы> <Дни_месяца> <Месяцы> <Дни_недели>

nnCron LITE может работать и с традиционными с "улучшенным" вариантом cron-формата, который отличается от традиционного шестым добавленным полем - <Годы>:

<Минуты> <Часы> <Дни_месяца> <Месяцы> <Дни_недели> <Годы>

Пользователь сам может выбрать подходящий для него формат, изменяя значение переменной YearField в файле настроек cron.ini. По умолчанию nnCron LITE использует традиционный формат, его мы и будем придерживаться в примерах

Вот его схема:

* * * * *
| | | | |
| | | | +----- Дни недели (диапазон: 1-7)
| | | +------- Месяцы     (диапазон: 1-12)
| | +--------- Дни месяца (диапазон: 1-31)
| +----------- Часы       (диапазон: 0-23)
+------------- Минуты     (диапазон: 0-59)

Любое из пяти полей может содержать символ * (звездочка) в качестве значения. Это означает полный диапазон возможных значений, например, каждая минута, каждый час и т. д. Пользователи nnCron LITE могут также использовать в первых четырех полях "нестандартный" символ - ?. См. его описание ниже.

Любое из полей может содержать список значений, разделенных запятыми (наприимер, 1,3,7) или интервал (поддиапазон) значений, обозначаемый дефисом (например, 1-5).

После звездочки (*) или интервала можно с помощью символа / указать шаг значений. Например, 0-23/2 может использоваться в поле "Часы" для указания того, что действие должно происходить каждые два часа (альтернатива из старого варианта - 0,2,4,6,8,10,12,14,16,18,20,22), значение */4 в поле "Минуты" означает, что действие, должно происходить каждые четыре минуты, 1-30/3 - это то же, что и 1,4,7,10,13,16,19,22,25,28.

В полях "Месяцы" и "Дни недели" можно вместо числовых значений использовать сокращенные до трех букв названия месяцев (Jan, Feb ... Dec) и дней недели (Mon, Tue ... Sun)

Примеры:

* * * * *                         каждую минуту

59 23 31 12 5                     за минуту до конца года, если последний день года -
                                  пятница
									
59 23 31 Dec Fri                  за минуту до конца года, если последний день года -
                                  пятница (еще один вариант записи)

45 17 7 6 *                       Каждый год 7-го июня в 17:45

0,15,30,45 0,6,12,18 1,15,31 * 1-5  В 00:00, 00:15, 00:30, 00:45, 06:00, 06:15, 06:30,
                                  06:45, 12:00, 12:15, 12:30, 12:45, 18:00, 18:15,
                                  18:30, 18:45, если сейчас 1-е, 15-е или 31-е число 
                                  любого месяца и только по рабочим дням недели

*/15 */6 1,15,31 * 1-5              В 00:00, 00:15, 00:30, 00:45, 06:00, 06:15, 06:30,
                                  06:45, 12:00, 12:15, 12:30, 12:45, 18:00, 18:15,
                                  18:30, 18:45, если сейчас 1-е, 15-е или 31-е число
                                  любого месяца и только по рабочим дням недели (еще 
                                  один вариант записи)

0 12 * * 1-5 (0 12 * * Mon-Fri)   В полдень по рабочим дням

* * * 1,3,5,7,9,11 *              Каждую минуту в январе, марте, мае, июле, сентябре
                                  и ноябре

1,2,3,5,20-25,30-35,59 23 31 12 * В последний день года в 23:01, 23:02, 23:03, 23:05,
                                  23:20, 23:21, 23:22, 23:23, 23:24, 23:25, 23:30,
                                  23:31, 23:32, 23:33, 23:34, 23:35, 23:59

0 9 1-7 * 1                       Первый понедельник каждого месяца, в 9 утра

0 0 1 * *                         В полночь, первого числа, каждый месяц

* 0-11 * *                        Каждую минуту до полудня

* * * 1,2,3 *                     Каждую минуту в январе, феврале и марте

* * * Jan,Feb,Mar *               Каждую минуту в январе, феврале и марте

0 0 * * *                         Каждый день в полночь

0 0 * * 3                         Каждую среду в полночь

Пользователи nnCron LITE могут использовать в первых четырех полях cron-формата нестандартный символ - ?. Он означает время старта nnCron, т. е. при обработке поля знак вопроса будет заменен на время старта nnCron LITE: минуты - для поля минут, час для поля часов, день месяца для поля дней месяца и месяц для поля месяца.

Например, если написать:

? ? * * *

то задача сработает в момент старта nnCron LITE и продолжит срабатывать ежедневно в это же самое время (если, конечно, пользователь не перезагрузит nnCron LITE снова) - знаки вопроса "заменятся" на время старта nnCron LITE. Если nnCron LITE стартовал, например, в 8:25, то знаки вопросов заменятся так:

25 8 * * *

Вот еще несколько примеров:

# запустится _только_ при старте nnCron LITE
? ? ? ? *
# запустится при старте nnCron LITE (например, в 10:15) 
# и продолжит запускаться ровно через один час: 
# в 11:15, 12:15, 13:15 и т. д.
? * * * *
# будет запускаться ежеминутно, в час старта nnCron LITE. 
# На следующий день (если крон не перезапускался) 
# в этот же час каждую минуту и т. д.
* ? * * *
# будет запускаться ежедневно, раз в пять минут, 
# в час старта nnCron LITE  
*/5 ? * * *