What Is Crontab ?
A crontab is a simple text file that holds a list of commands that are to be run at specified times. These commands, and their related run times, are controlled by the cron daemon and are executed in the system's background. More information can be found by viewing the crontab's man page. We will run through a simple crontab example later.
How Does It Work ?
The system maintains a crontab for each user on the system. In order to edit or create a crontab, you must use the text editor that is specified by your system. The vi text editor is the default text editor on a Mandrake 10.0 Official system. This text editor must be opened with the command crontab using the -e option. To create a crontab open a term and type:
crontab -e
The vi text editor will open with a blank window for the desired times and commands to be entered. Each line represents a seperate crontab entry - also known as a "cron job". If you are not familiar with the vi text editor you should read the following page: Using VI. Each of the sections is separated by a space, with the final section having one or more spaces in it. No spaces are allowed within Sections 1-5, only between them. Sections 1-5 are used to indicate when and how often you want the task to be executed.
How Crontab Options Are Specified
This is how a cron job is layed out: minute (0-59), hour (0-23, 0 = midnight), day (1-31), month (1-12), weekday (0-6, 0 = Sunday), command
Crontab For A Certain Day Of A Certain Date
01 04 1 1 1 /usr/bin/somedirectory/somecommand
The above example will run /usr/bin/somedirectory/somecommand at 4:01am on any Monday which falls on January 1st. An asterisk (*) can be used so that every instance (every hour, every weekday, every month, etc.) of a time period is used.
Crontab For Everyday Of The Month
01 04 * * * /usr/bin/somedirectory/somecommand
The above example will run /usr/bin/somedirectory/somecommand at 4:01am on every day of every month.
Comma-seperated values can be used to run more than one instance of a particular command within a time period. Dash-seperated values can be used to run a command continuously.
Crontab For Specified Day Of Specified Month(s)
01,31 04,05 1-15 1,6 * /usr/bin/somedirectory/somecommand
The above example will run /usr/bin/somedirectory/somecommand at 01 and 31 past the hours of 4:00am and 5:00am on the 1st through the 15th of every January and June.
The /usr/bin/somedirectory/somecommand text in the above examples indicates the task which will be run at the specified times. It is recommended that you use the full path to the desired commands as shown in the above examples. The crontab will begin running as soon as it is properly edited and saved.
Various Options/Flags Crontab Can Use
The -l option causes the current crontab to be displayed on standard output.
The -r option causes the current crontab to be removed.
The -e option is used to edit the current crontab using the editor specified by the VISUAL or EDITOR environment variables.
After you exit from the editor, the modified crontab will be checked for accuracy and, if there are no errors, installed automatically.
Daily Crontab Example
Below is an example of how to setup a crontab to run updatedb, which updates the slocate database:
Open konsole and type crontab -e and press enter, The vi editor will open in COMMAND mode, press the I key to enter INSERT mode, Type the following line, substituting the full path for the one shown below, into the vi editor:
45 04 * * * /usr/bin/updatedb
Press the ESC key to exit INSERT mode and return to COMMAND mode, Type :wq to save and exit the file.
Crontab will let you know if you made any mistakes. The crontab will be installed and begin running if there are no errors.
That's it. You now have a cron job setup to run updatedb, which updates the slocate database, every morning at 4:45.
Daily Crontab With Multiple Commands
The double-ampersand (&&) can also be used in the command section to run multiple commands consecutively.
45 04 * * * /usr/sbin/chkrootkit && /usr/bin/updatedb
The above example will run chkrootkit and updatedb at 4:45am daily.
You can also specify a user that you want to setup a crontab entry for by doing the following command:
crontab -e -u <user>
You'll want to replace the <user> with the username which you wish to set the crontab entry for.
