Java Cron Expression

The technology is constantly changing day by day. Sometimes, we are required to execute a job periodically on the server. Running the job on the server manually is a difficult task so, it cannot be done multiple times by the user or administrator. In order to resolve this problem, Cron helps the programmer to execute a job periodically on the server. It is widely used for automated system maintenance and admiration. Beside this, we can also use Cron expression in web development. There are many situations when a web application may need to execute a certain task periodically.

In this section, we will discuss the Java Cron expressions, it's working and implementation through Java Quartz scheduler.

What is Cron?

Basically, Cron is a utility that schedules a task. It allows user to schedule a task periodically at specified time, date, month, weak, and year. It is widely used in automated process where human intervention is not required.

Java Cron Expression

Cron Expression

In Java, Cron expressions are used to configure instances of the CronTrigger class. It is a subclass of org.quartz.Trigger class. A Cron expression is a string or expression consisting of six or seven fields (time unit). It describes individual details of the schedule and the command.

A cron expression may simple as well as complex. For example,

Simple: * * * * ? * (asterisk denotes fields)

Complex: 0 0/4 12,15,3-35,52 ? May,June,july TUE-SAT 2002-2010.

Also, note that a Cron expression can be written in different styles, as follows. For example, The following three Cron expression have the same meaning.

  • 0 10 9 ? * *
  • 0 10 9 * * ?
  • 0 10 9 * * ? *

All the three expressions, execute at 9:10 AM every day.

Fields Used in Cron Expression

In Cron expressions, time unit is known as field. These are separated by white space, can contain any of the allowed values with various combinations of the allowed characters for that field. It shows the fields in the expected order. The following table depicts the time unit and corresponding values, and symbols that can be used with the expressions.

Field NameRequiredAllowed ValuesAllowed Special Characters and Symbols with Fields
SecondsYes0-59, - * /
MinutesYes0-59, - * /
HoursYes0-23, - * /
Day of monthYes-31, - * ? / L W C
MonthYes0-11 or JAN-DEC, - * /
Day of weekYes1-7 or SUN-SAT, - * ? / L C #
YearOptionalempty or 1970-2099, - * /

Special Symbols and Letters Used in Cron Expression

Asterisk (*): The symbol is used when we want to execute event at every time unit (minute, second, hour). For example, if * is used with minute time unit, it means an event will execute at every minute, automatically.

Question Mark (?): The symbol is used in the fields like day of month and day of week. It denotes the arbitrary value and ignores the fields value. Suppose, we want to execute a script on 2nd of every month without caring about what day of the week fall in the 2nd day of the month. In this case, we should specify a question mark symbol (?) in the day of week field.

Hyphen (-): The symbol is used to specify the range. It determines the range of values. For example, if an hour field is defined as <4-5>, means an event will execute at 4th and 5th hour.

Comma (,): It is used to define values of the fields separated by comma. For example, Fri, Sat, Sun, etc.

Forward Slash (/): It is used to increment values of the specified time unit. Suppose, we want to start an event at 10 minutes, after that we are required to execute the same event at 20-minute, next execution at 30 minutes, and so on. In this case, we specify the start time and the incremental value, separated by forward slash.

For example, if 10/10 in specified in the minute field, it means first event execute at 10 minutes, and the next execution will be at 20-minutes of an hour, and so no.

L (Last): The use of L has different meaning with various fields.

  • If it has been used in the <day-of-month> field, it denotes the last day of the month, according to calendar.
  • If it has been used with an offset value like L-5. It denotes the 5th to last day of the calendar month.
  • If it has been used in the <day-of-week> field, it denotes the last day of the week. It can also be used with other value in the <day-of-week> field. For example, 7L denotes the last Saturday.

W: The later represents the weekdays (Monday to Friday). It determines the weekday that is nearest to the specified day of the month.

For example, if we specify 5W in the day of month field, it means w determine the weekday near to the 5th of the month.

  • If the 5th of the month is Saturday, an event will trigger on 9th of the month.
  • If the 5th of the month is Sunday, an event will trigger on 11th of the month.

There may exist another case. Suppose, 1st of the month is Saturday, an event will occur on 3rd of the month. It means that event or script will not execute in the previous month.

Hash (#): It represents the n-th occurrence of a weekday of the month. For example, third Friday of the month can be indicated as 6#3.

Why we should use cron expressions?

There are various reasons to use cron expressions. Some of them are:

  • We can expire and erase cached data files at certain interval.
  • We can schedule daily news letter and e-mails.
  • We can schedule long-running tasks to run from a command line script, rather than running it from a web script. Like encoding videos, or sending out bulk e-mails.

Example of Cron Expressions

Let's see some common Cron expressions that uses special symbol and fields.

Cron ExpressionMeaning of Cron Expressions
0 12 * * ?It denotes that a job will execute at 12:00 PM (noon) every day.
0/5 13,18 * * ?It denotes that a job will execute at every five minutes starting at 1 PM and ending at 1:55 PM and then starting at 6 PM and ending at 6:55 PM, every day.
0-5 13 * * ?It denotes that a job will execute at every minute starting at 1 PM and ending at 1:05 PM, every day.
15,45 13 ? 6 TueIt denotes that a job will execute at 1:15 PM and 1:45 PM every Tuesday in the month of June.
30 9 ? * MON-FRIIt denotes that a job will execute at 9:30 AM every Monday, Tuesday, Wednesday, Thursday, and Friday.
30 9 15 * ?It denotes that a job will execute at 9:30 AM on the 15th day of every month.
0 18 L * ?It denotes that a job will execute at 6 PM on the last day of every month.
0 18 L-3 * ?It denotes that a job will execute at 6 PM on the third to last day of every month.
30 10 ? * 5LIt denotes that a job will execute at 10:30 AM on the last Thursday of every month.
0 10 ? * 2#3It denotes that a job will execute at 10 AM on the third Monday of every month.
0 0 10/5 * ?It denotes that a job will execute at 12 midnight on every day for five days starting on the 10th day of the month.
0 11 11 11 11 ?It denotes that a job will execute on every November 11th at 11:11 AM
0 15 10 ? * 6L 2002-2005Fire at 10:15 AM on every last Friday of every month during the years 2002, 2003, 2004, and 2005.
0 0 0 ? * MON#1It denotes that a job will execute on first Monday in the month at midnight.
0 0 0 LW * *It denotes that a job will execute on last weekday of the month at midnight.
0 0/30 8-10 * * *It denotes that a job will execute at 8:00, 8:30, 9:00, 9:30, 10:00 and 10:30 every day.

Special Setting in Cron Expressions

Besides the above special symbol, Cron expression also support some predefined special values. These values can be used instead of the fields.

  • @yearly or @annually: It runs a job once in a year. For example, "0 0 0 1 1 *".
  • @monthly: It runs job once in a month. For example, "0 0 0 1 * *".
  • @weekly: It runs job once in a week. For example, "0 0 0 * * 0".
  • @daily or @midnight: It runs job once a day. For example, "0 0 0 * * *".
  • @hourly: It runs job hourly. For example, "0 0 * * * *".

Using Cron Expression in Java

Java provides an open source job scheduling system that schedules a job for a specific time unit. We can download Quartz scheduler from the official site.

In terms of programming, job is a class that contains the task to be executed. But the question is how to schedule it. For scheduling a job, we define a trigger and specified when the job will execute.

If we want to implement Quartz scheduler, we can add the dependency, as follows:

Note: Before executing the following Java program, ensure that you have added quartz-2.2.1.jar file in the path, else you will get error.

Let's see the implementation of cron expression and job through a Java program.

Step 1: Create a Maven project. We have created with the name CronExample.

Step 2: Inside the project, create two packages namely com.javatpoint.app and com.javatpoint.job. In the first package, we will define the main class and in the second package we will define the jobs (in our case number of jobs is five).

Step 3: In the pom.xml file, paste the following dependency. It automatically downloads the required JAR files for the project. The pom file looks like the following:

Step 4: Create five jobs (in com.javatpoint.job package) that you want to execute. In our case, we have defined the following five jobs.

Job1.java

Job2.java

Job3.java

Job4.java

Job5.java

Step 5: Create the main class with the name MyApp.

MyApp.java

When we done with all the above steps, the project directory looks like the following:

Java Cron Expression

Step 6: Run the above Java program to see the output.

Java Cron Expression

We observe that every job is executing at specific time interval.






Latest Courses