Skip to main content

How to set a crontab

How to Use the Cron and Crontab commands

The 'Cron' Command

The cron command starts a process that executes commands at specified dates and times. Regularly scheduled commands can be specified according to instructions found in the crontab files in the directory /var/spool/cron/crontabs. Users can submit their own crontab files via the crontab command.

The 'Crontab' Command

Crontab copies the specified file or standard input if no file is specified, into a directory that holds all users' crontabs.

SYNOPSIS:

  • crontab [file]
  • crontab -e [-u username]
  • crontab -r [-u username]
  • crontab -l [-u username]

The -e option edits a copy of the current users' crontab file or creates an empty file to edit if crontab does not exist.

The-r option removes a user's crontab from the crontab directory.

The -l options lists the crontab file for the invoking user.

Setting up a Crontab job

A crontab file consists of lines of six fields each.The fields are separated by spaces or tabs. The first five are integers that specify the following:

  1. minute (0-59),
  2. hour (0-23),
  3. day of the month (1-31),
  4. month of the year (1-12),
  5. day of the week (0-6 with 0=Sunday).

Each of these patterns may be either an asterisk (meaning all valid values) or a list of elements separated by commas. An element is either a number or two numbers separated by a minus sign ( meaning an inclusive range). Notice the time is in 24 hour format, 0 is midnight and 13 is one in the afternoon.

The sixth field of a line in a crontab file is a string to be executed by the shell at the specified times by the first fife fields. A percent character in this field (unless escaped by \) is translated to a newline character. Only the first line (up to a % or end of line) of the command field is executed by the shell. The other lines are made available to the command as standard input.

Any line beginning with a # is a comment and is ignored.

Example

To illustrate, 0 0 1,15 1 would run a command on the first and fifteenth of each month, as well as on every Monday at exactly midnight. To specify days by only one field, the other field should be set to *. The entry, 0 23 * * 1 would run a command only on Mondays at eleven PM.

A minute specification of 0,30 would indicate the job is to be run on the hour and half hour. Likewise, a day of the month entry of 1,15 would initiate execution on the first and fifteenth of the month.

Make sure you include an explicit path to your programs or scripts that you want to run by crontab. Let's assume we want to execute a Perl program, autoclose.cgi, every day at midnight. Additionally assume the full path to the script is /home/www/yourdirectory/cgi-bin. The full crontab command would be: 0 0 * * * /home/www/yourdirectory/cgi-bin/autoclose.cgi

Execute at midnight, every day of the month, every month of the year, and every day of the week.

If you're not sure of the full path to your script, go to the directory and issue the command:

pwd

This is the "print working directory" command. The requirement for explicit paths also apply to any "require" library file used in a Perl script.

The line:

0 0 1,15 * 1 /home/www/yourdirectory/cgi-bin/autoclose.cgi

runs the command on the first and fifteeth of each month, as well as on every Monday.

The line:

0 0 * * 1 /home/www/yourdirectory/cgi-bin/autoclose.cgi

runs a the command only on Mondays.

Putting it all together

Creating your first crontab job is a three-part process:

  1. Prepare the absolute path to the program or script that you want to run,
  2. Create a text file containing a line to schedule the job as described above for crontab fields,
  3. Upload the text file to your system cron.


When preparing program to run or creating scripts to run remember that crontab jobs are background tasks. There is no terminal attached to a crontab job so there should be no print statements that normally write to the screen. (It is possible to redirect such print statements.) The same consideration hold true for requesting user input.

Let's assume that we want to run this script:

/home/www/yourdirectory/cgi-bin/autoclose.cgi

Next create a file to hold your crontab instructions. Let's call it "cron.txt". Let's also have our script execute at zero minute every hour. Put the following crontab command line in the text file "cron.txt" and save this file as a text file: 0 * * * * /home/www/yourdirectory/cgi-bin/autoclose.cgi

The last step is uploading the contents of your "cron.txt" file to the system crontab spool area. Enter the following at the system prompt.

crontab cron.txt

Now you are done with this project.

If you would like additional detailed information on crontab, enter the following at your Unix prompt.

man crontab

Comments

Popular posts from this blog

How to Use Chisanbop (Korean Finger Math) for Basic Addition and Counting | eHow.com

How to Use Chisanbop (Korean Finger Math) for Basic Addition and Counting eHow.com Difficulty: Easy Instructions Step 1 In Chisanbop you'll be using your two hands and ten fingers to represent numbers from 0 to 99. Start out with your hands out in front of you with closed fists. This represents 0. Each finger (not thumb) on your right hand represents 1. To represent 3, just press down three right hand fingers. Your right thumb represents 5. To represent 7, press down your right thumb and 2 right hand fingers. Think of your right hand as the ones or units place (column). Step 2 Your left hand represents the tens place (column). Each finger on your left hand is worth 10. For example, to represent 30, press down three left hand fingers. To represent 38, do the same, but also use your right hand to represent 8 as described above. Your left thumb represents 50. To represent 86, press down your left thumb and three left hand fingers for the 80, and your right thumb and one righ

How to load the sample database into the MariaDB server.

1. Download  the Sample Database  (Source :  https://www.mariadbtutorial.com/getting-started/mariadb-sample-database/  ) 2. unzip the file to a directory e.g.,  c:\mariadb\nation.sql 2.   connect to the MariaDB server  with the  root  user account, type the password and press the   Enter  keyboard. sudo mysql -u root -p Enter password: ******** 3.  Load the database by using the source command: mysql>source c:\mariadb\nation.sql 4.  select the   nation   database and display tables of the database: mysql> use nation; Database changed mysql> show tables ;