Making things happen on a regular and predictable schedule is important on computers. It's important because, as humans, we can sometimes be bad at remembering to do things reliably because we get distracted, have too much on our minds, or we're on holiday. Computers are really good at doing things on a schedule, but a human has to program the computer before the computer takes action.
In a way, the cron
system is an easy and rudimentary introduction to programming. You can make your computer do what you want it to do just by editing a file. You don't even have to know where the file is kept. You have only to type in a simple command, enter the "recipe" you want your computer to follow, and save your work. From then on, your computer executes your instructions at the specified time until it is told to stop.
By design, cron
is not a complex system. Here's what you need to know about it.
What is cron?
The cron
command is so ubiquitous in Linux and Unix, and it's been mimicked and reinvented so often that it's almost a generic term for something that happens on a schedule. It's a form of automation, and although there are different implementations of it (Dillon's cron, Vixie's cron, chrony, and others), and variations like anacron
and systemd timers, the syntax and workflow has remained essentially the same for decades.
Cron works on a "spool" system, much like printers and email. If you didn't know that printers and email use a spool, that's okay because the point of a spool file is that you aren't supposed to think about it much. On a Linux system, the directory /var/spool
is designed as a central hub for important but low-level files that the user isn't meant to interact with directly. One of the spools managed in /var/spool
is cron
tables or "crontab" for short. Every user—yourself included—on a Linux system has a crontab. Users can edit, view, and remove their own crontab. In addition, users can use their crontab to schedule tasks. The cron
system itself monitors crontabs and ensures that any job listed in a crontab is executed at its specified time.
Edit cron settings
You can edit your crontab using the crontab
command along with the -e
(for edit) option. By default, most systems invoke the vim
text editor. If you, like me, don't use Vim, then you can set a different editor for yourself in your ~/.bashrc
file. I set mine to Emacs, but you might also try Nano, Kate, or whatever your favorite editor happens to be. The EDITOR environment variable defines what text editor you use in your terminal, while the VISUAL variable defines what editor you use in a graphical mode:
export EDITOR=nano
export VISUAL=kate
Refresh your shell session with your new settings:
$ source ~/.bashrc
Now you can edit your crontab with your preferred editor:
$ crontab -e
Schedule a task
The cron
system is essentially a calendaring system. You can tell cron
how frequently you want a job to run by using five different attributes: minute, hour, date, month, weekday. The order of these attributes is strict and not necessarily intuitive, but you can think of them as filters or masks. By default, you might think of everything being set to always or every. This entry would run touch /tmp/hello
at the top of every minute during every hour of every day all year long:
* * * * * touch /tmp/hello
You can restrict this all-encompassing schedule by setting specific definitions for each attribute. To make the job run on the half-hour mark of each hour, set the minutes to 30:
30 * * * * touch /tmp/hello
You can further constrain this instruction with a specific hour. This job runs at 3:30 AM every morning:
30 3 * * * touch /tmp/hello
You can also make the job run only on the first of each month:
30 3 1 * * touch /tmp/hello
You can set a month using 1 for January up to 12 for December, and you can set a day using 0 for Sunday up to 6 for Saturday. This job runs at 3:15 during the month of April, only on Mondays:
15 3 * 4 1 touch /tmp/hello
Set increments
All of these settings match a value exactly. You can also use cron
notation to run jobs after a set passage of time. For instance, you can run a job every 15 minutes:
*/15 * * * * touch /tmp/hello
You could run a job at 10 AM every three days:
* 10 */3 * * touch /tmp/hello
You could run a job every six hours:
* */6 * * * touch /tmp/hello
Cron shorthand
Modern cron
implementations have added a convenient shorthand for common schedules. These are:
@hourly
@daily
@weekly
@monthly
@yearly or @annually
List cron jobs
Using the crontab
command, you can see a list of your scheduled cron
jobs:
$ crontab -l
15 3 * 4 1 touch /tmp/hello
Remove a crontab
When you're done with a crontab, you can remove it with the -r
option:
$ crontab -r -i
The -i
option stands for interactive. It prompts you for confirmation before deleting the file.
What cron can do
It's one thing to know how to use cron
, but it's another thing to know what to use it for. The classic use case is a good backup plan. If your computer is on for most of the day or all day and all night, then you can schedule a routine backup of an important partition. I run a backup application called rdiff-backup
on my primary data partition daily at 3AM:
$ crontab -l | grep rdiff
* 3 * * * rdiff-backup /data/ /vault/
Another common use is system maintenance. On my Slackware desktop, I update my local repository catalog every Friday afternoon:
$ crontab -l | grep slack
* 14 * * 5 sudo slackpkg update
I could also run an Ansible script at 15:00 every three days to tidy up my Downloads folder:
$ crontab -l | grep ansible
* 15 */3 * * ansible-playbook /home/seth/Ansible/cleanup.yaml
A little investment in the health of your computing environment goes a long way. There are de-duplication scripts, file size and /tmp
directory monitors, photo resizers, file movers, and many more menial tasks you could schedule to run in the background to help keep your system uncluttered. With cron
, your computer can take care of itself in ways I only wish my physical apartment would.
Remember cron settings
Besides coming up with why you need cron
, the hardest thing about cron
in my experience has been remembering its syntax. Repeat this to yourself, over and over until you've committed it to memory:
Minutes, hours, date, month, weekday.
Minutes, hours, date, month, weekday.
Minutes, hours, date, month, weekday.
Better yet, go download our free cheatsheet so you have the key close at hand when you need it the most!
1 Comment