This article includes a list of general references, but it lacks sufficient corresponding inline citations. (September 2017) |
anacron is a computer program that performs periodic command scheduling, which is traditionally done by cron, but without assuming that the system is running continuously. Thus, it can be used to control the execution of daily, weekly, and monthly jobs (or anything with a period of n days) on systems that don't run 24 hours a day. anacron was originally conceived and implemented by Christian Schwarz in Perl, for the Unix operating system. It was later rewritten in C by Itai Tzur; maintainers have included Sean 'Shaleh' Perry and Pascal Hakim.[1]
Original author(s) | Christian Schwarz |
---|---|
Developer(s) | Itai Tzur, Pascal Hakim, Marcela Mašláňová (Red Hat) |
Stable release | 2.3
/ June 22, 2000 |
Repository | |
Written in | C |
Operating system | Linux |
Platform | POSIX |
Type | Job scheduler |
Website | sf |
Since 2009, Red Hat's cron implementation, cronie, has included anacron.[2][3] Since then, anacron has been updated by Red Hat as a part of cronie.[4]
Advantages
Unix systems commonly run "housekeeping chores" such as log rotation, unused files deletion, indexing local files for the search engine, sending disk usage reports, etc. A program called cron may be used to schedule these tasks.
With cron, tasks are commonly scheduled to be executed when the system is expected to be idle. If the system is off at the moment a task should be run, it will not be executed. Anacron is different and moves tasks to different moments so they are run when the system is on and utilising cron.
Disadvantages
Only the system administrator can configure anacron tasks. In contrast, cron allows non-admin users to configure scheduled tasks. If necessary, a non-admin user can use the at Unix command to request a scheduled task (which is guaranteed to run). Upon starting, this command can then automatically request to run itself at a future date, thus giving the appearance of a regularly scheduled task, with guaranteed execution.
anacron can run tasks only once a day (or less often such as weekly or monthly). In contrast, cron allows tasks to run as often as every minute (but does not guarantee their execution if the system goes down). In practice, this is not usually an issue, since it is rare to have a task that must be guaranteed to run more often than (at least) once a day — especially on a system that is not necessarily running at all times.
If the system is rebooted or started after midnight, the daily tasks are run after a user-specified delay in synchronized fashion (sequential order), so only one anacron-task is running at a time. When that task is finished, the next one starts and so on.
This behaviour can be overridden to allow concurrent (parallel) tasks, but can consume system resources that are needed by the user to do work. In contrast, cron will only run daily tasks at the time set (e.g. in the middle of the night, when presumably the machine is not being used).
fcron is another implementation of cron, which attempts to fulfill the roles of both Vixiecron and anacron.
See also
References
- ^ "anacron(8): runs commands periodically - Linux man page". 2018-01-25. Archived from the original on 2018-01-25. Retrieved 2018-03-31.
- ^ "Initial upload of anacron-2.3 which should be optimized for better · cronie-crond/cronie@55f4057". GitHub.
- ^ "7.33. cronie - Red Hat Customer Portal". 2018-03-31. Archived from the original on 2018-03-31. Retrieved 2018-03-31.
- ^ "cronie-crond/cronie - ChangeLog". GitHub. Retrieved 2018-03-31.
External links
- anacron on SourceForge
- anacron(8) – Linux Programmer's Manual
- fcron