cronbot - Gain more control over your cron jobs and how they run.
cronbot [full path to your regular cron job]
Options: --rand xx Add a max random number of minutes to wait before starting job. Default is 30 minutes if not otherwise specified. --duplicate Allow this job to run more than once --timer xx Specify a max execution time. Longer than this and it will be killed hard --nonice Do not run the job through nice (man nice) --touchfile Update the modtime on this file after the job completes. Useful for freshness checking. --logfile File to log info and error messages (uses syslog by default) --loadlimit x.x Max 1min load load. Over this value the script waits for the load to drop. Max delay about 2 hours. --man Full man page
15 * * * * root /usr/local/bin/cronbot --timer 90 --rand 10 /usr/local/bin/rsync -a /home /mnt/remote/home
This would attempt to run rsync every hour but will not start a duplicate job if it's still running. It will hard kill the job if it's running for more than 90 minutes and it will add a random delay between 1 and 10 minutes before starting the job.
15 * * * * root /usr/local/bin/cronbot --logfile /var/log/cronitem1.log --tf /var/fresh/cronitem1 /usr/local/bin/rsync -a /home /mnt/remote/home
This example logs output to a file rather than syslog and updated the time stamp on /var/fresh/cronitem1 when the job finishes. These can be useful for other automation to detect jobs that aren't running as expected.
Cronbot is a wrapper script for cron jobs. Rather than running your job/script directly you run it through cronbot and it will allow a little more control to help keep things from getting out of hand. The default behavior is to only allow one instance of your job to run. This can be changed with the --duplicate option. You can also pass in a maximum time of execution for a job or add a random amount time to delay the start of your job. You can also specify a maximum load value.. if the systm is over this value it will wait with an exponential backoff and keep trying.. up to about 2 hours. Also by default jobs are run with a default 'nice' value which is usually 10 (man nice).
Requires Sys::Syslog for logging to syslog or specify a logfile with --logfile
COPYRIGHT AND LICENSE
Copyright 2013 Jared Watkins
This is released under the GNU General Public License (GPL-2.0)
Get it at: