converted rdoc files to markdown
This commit is contained in:
parent
974b5a2016
commit
46da1bc6f8
@ -1,4 +1,4 @@
|
|||||||
== 0.6.1 / October 20th, 2010
|
### 0.6.1 / October 20th, 2010
|
||||||
|
|
||||||
* Detect script/rails file and change runner to Rails 3 style if found. [Javan Makhmali]
|
* Detect script/rails file and change runner to Rails 3 style if found. [Javan Makhmali]
|
||||||
|
|
||||||
@ -7,14 +7,14 @@
|
|||||||
* Added a built-in Capistrano recipe. [Javan Makhmali]
|
* Added a built-in Capistrano recipe. [Javan Makhmali]
|
||||||
|
|
||||||
|
|
||||||
== 0.5.3 / September 24th, 2010
|
### 0.5.3 / September 24th, 2010
|
||||||
|
|
||||||
* Better regexes for replacing Whenever blocks in the crontab. #45 [Javan Makhmali]
|
* Better regexes for replacing Whenever blocks in the crontab. #45 [Javan Makhmali]
|
||||||
|
|
||||||
* Preserving backslashes when updating existing crontab. #82 [Javan Makhmali]
|
* Preserving backslashes when updating existing crontab. #82 [Javan Makhmali]
|
||||||
|
|
||||||
|
|
||||||
== 0.5.2 / September 15th, 2010
|
### 0.5.2 / September 15th, 2010
|
||||||
|
|
||||||
* Quotes automatically escaped in jobs. [Jay Adkisson]
|
* Quotes automatically escaped in jobs. [Jay Adkisson]
|
||||||
|
|
||||||
@ -25,7 +25,7 @@
|
|||||||
* Lots of internal reorganizing; tests broken into unit and functional. [Javan Makhmali]
|
* Lots of internal reorganizing; tests broken into unit and functional. [Javan Makhmali]
|
||||||
|
|
||||||
|
|
||||||
== 0.5.0 / June 28th, 2010
|
### 0.5.0 / June 28th, 2010
|
||||||
|
|
||||||
* New job_type API for writing custom jobs. Internals use this to define command, runner, and rake. [Javan Makhmali - inspired by idlefingers (Damien)]
|
* New job_type API for writing custom jobs. Internals use this to define command, runner, and rake. [Javan Makhmali - inspired by idlefingers (Damien)]
|
||||||
|
|
||||||
@ -34,7 +34,7 @@
|
|||||||
* --clear option to remove crontab entries for a specific [identifier]. [mraidel (Michael Raidel)]
|
* --clear option to remove crontab entries for a specific [identifier]. [mraidel (Michael Raidel)]
|
||||||
|
|
||||||
|
|
||||||
== 0.4.2 / April 26th, 2010
|
### 0.4.2 / April 26th, 2010
|
||||||
|
|
||||||
* runners now cd into the app's directory and then execute. [Michael Guterl]
|
* runners now cd into the app's directory and then execute. [Michael Guterl]
|
||||||
|
|
||||||
@ -45,49 +45,49 @@
|
|||||||
* bugfix: comparison Time with 0 failed. #32 [Dan Hixon]
|
* bugfix: comparison Time with 0 failed. #32 [Dan Hixon]
|
||||||
|
|
||||||
|
|
||||||
== 0.4.1 / November 30th, 2009
|
### 0.4.1 / November 30th, 2009
|
||||||
|
|
||||||
* exit(0) instead of just exit to make JRuby happy. [Elan Meng]
|
* exit(0) instead of just exit to make JRuby happy. [Elan Meng]
|
||||||
|
|
||||||
* Fixed activesupport deprecation warning by requiring active_support. #37 [Andrew Nesbitt]
|
* Fixed activesupport deprecation warning by requiring active_support. #37 [Andrew Nesbitt]
|
||||||
|
|
||||||
|
|
||||||
== 0.4.0 / October 20th, 2009
|
### 0.4.0 / October 20th, 2009
|
||||||
|
|
||||||
* New output option replaces the old cron_log option for output redirection and is much more flexible. #31 [Peer Allan]
|
* New output option replaces the old cron_log option for output redirection and is much more flexible. #31 [Peer Allan]
|
||||||
|
|
||||||
* Reorganized the lib files (http://weblog.rubyonrails.org/2009/9/1/gem-packaging-best-practices) and switched to Jeweler from Echoe.
|
* Reorganized the lib files (http://weblog.rubyonrails.org/2009/9/1/gem-packaging-best-practices) and switched to Jeweler from Echoe.
|
||||||
|
|
||||||
|
|
||||||
== 0.3.7 / September 4th, 2009
|
### 0.3.7 / September 4th, 2009
|
||||||
|
|
||||||
* No longer tries (and fails) to combine @shortcut jobs. #20 [Javan Makhmali]
|
* No longer tries (and fails) to combine @shortcut jobs. #20 [Javan Makhmali]
|
||||||
|
|
||||||
|
|
||||||
== 0.3.6 / June 15th, 2009
|
### 0.3.6 / June 15th, 2009
|
||||||
|
|
||||||
* Setting a PATH in the crontab automatically based on the user's PATH. [Javan Makhmali]
|
* Setting a PATH in the crontab automatically based on the user's PATH. [Javan Makhmali]
|
||||||
|
|
||||||
|
|
||||||
== 0.3.5 / June 13th, 2009
|
### 0.3.5 / June 13th, 2009
|
||||||
|
|
||||||
* Added ability to accept lists of every's and at's and intelligently group them. (ex: every 'monday, wednesday', :at => ['3pm', '6am']). [Sam Ruby]
|
* Added ability to accept lists of every's and at's and intelligently group them. (ex: every 'monday, wednesday', :at => ['3pm', '6am']). [Sam Ruby]
|
||||||
|
|
||||||
* Fixed issue with new lines. #18 [Javan Makhmali]
|
* Fixed issue with new lines. #18 [Javan Makhmali]
|
||||||
|
|
||||||
== 0.3.1 / June 25th, 2009
|
### 0.3.1 / June 25th, 2009
|
||||||
|
|
||||||
* Removed activesupport gem dependency. #1 [Javan Makhmali]
|
* Removed activesupport gem dependency. #1 [Javan Makhmali]
|
||||||
|
|
||||||
* Switched to numeric days of the week for Solaris support (and probably others). #8 [Roger Ertesvåg]
|
* Switched to numeric days of the week for Solaris support (and probably others). #8 [Roger Ertesvåg]
|
||||||
|
|
||||||
|
|
||||||
== 0.3.0 / June 2nd, 2009
|
### 0.3.0 / June 2nd, 2009
|
||||||
|
|
||||||
* Added ability to set variables on the fly from the command line (ex: whenever --set environment=staging). [Javan Makhmali]
|
* Added ability to set variables on the fly from the command line (ex: whenever --set environment=staging). [Javan Makhmali]
|
||||||
|
|
||||||
|
|
||||||
== 0.2.2 / April 30th, 2009
|
### 0.2.2 / April 30th, 2009
|
||||||
|
|
||||||
* Days of week jobs can now accept an :at directive (ex: every :monday, :at => '5pm'). [David Eisinger]
|
* Days of week jobs can now accept an :at directive (ex: every :monday, :at => '5pm'). [David Eisinger]
|
||||||
|
|
||||||
@ -96,22 +96,22 @@
|
|||||||
* Raising an exception if someone tries to specify an :at with a cron shortcut (:day, :reboot, etc) so there are no false hopes. [Javan Makhmali]
|
* Raising an exception if someone tries to specify an :at with a cron shortcut (:day, :reboot, etc) so there are no false hopes. [Javan Makhmali]
|
||||||
|
|
||||||
|
|
||||||
== 0.1.7 / March 5th, 2009
|
### 0.1.7 / March 5th, 2009
|
||||||
|
|
||||||
* Added ability to update the crontab file non-destuctively instead of only overwriting it. [Javan Makhmali -- Inspired by code submitted individually from: Tien Dung (tiendung), Tom Lea (cwninja), Kyle Maxwell (fizx), and Andrew Timberlake (andrewtimberlake) on github]
|
* Added ability to update the crontab file non-destuctively instead of only overwriting it. [Javan Makhmali -- Inspired by code submitted individually from: Tien Dung (tiendung), Tom Lea (cwninja), Kyle Maxwell (fizx), and Andrew Timberlake (andrewtimberlake) on github]
|
||||||
|
|
||||||
|
|
||||||
== 0.1.5 / February 19th, 2009
|
### 0.1.5 / February 19th, 2009
|
||||||
|
|
||||||
* Fixed load path so Whenever's files don't conflict with anything in Rails. Thanks Ryan Koopmans. [Javan Makhmali]
|
* Fixed load path so Whenever's files don't conflict with anything in Rails. Thanks Ryan Koopmans. [Javan Makhmali]
|
||||||
|
|
||||||
|
|
||||||
== 0.1.4 / February 17th, 2009
|
### 0.1.4 / February 17th, 2009
|
||||||
|
|
||||||
* Added --load-file and --user opts to whenever binary. [Javan Makhmali]
|
* Added --load-file and --user opts to whenever binary. [Javan Makhmali]
|
||||||
|
|
||||||
|
|
||||||
== 0.1.3 / February 16th, 2009
|
### 0.1.3 / February 16th, 2009
|
||||||
|
|
||||||
* Added 'rake' helper for defining scheduled rake tasks. [Javan Makhmali]
|
* Added 'rake' helper for defining scheduled rake tasks. [Javan Makhmali]
|
||||||
|
|
||||||
@ -124,6 +124,6 @@
|
|||||||
* Requiring specific gem versions: Chronic >=0.2.3 and activesupport >= 1.3.0 [Javan Makhmali]
|
* Requiring specific gem versions: Chronic >=0.2.3 and activesupport >= 1.3.0 [Javan Makhmali]
|
||||||
|
|
||||||
|
|
||||||
== 0.1.0 / February 15th, 2009
|
### 0.1.0 / February 15th, 2009
|
||||||
|
|
||||||
* Initial release [Javan Makhmali]
|
* Initial release [Javan Makhmali]
|
@ -1,119 +1,119 @@
|
|||||||
== Introduction
|
### Introduction
|
||||||
|
|
||||||
Whenever is a Ruby gem that provides a clear syntax for writing and deploying cron jobs.
|
Whenever is a Ruby gem that provides a clear syntax for writing and deploying cron jobs.
|
||||||
|
|
||||||
== Installation
|
### Installation
|
||||||
|
|
||||||
$ gem install whenever
|
$ gem install whenever
|
||||||
|
|
||||||
Or with Bundler in your Gemfile.
|
Or with Bundler in your Gemfile.
|
||||||
|
|
||||||
gem 'whenever', :require => false
|
gem 'whenever', :require => false
|
||||||
|
|
||||||
== Getting started
|
### Getting started
|
||||||
|
|
||||||
$ cd /my/rails/app
|
$ cd /my/rails/app
|
||||||
$ wheneverize .
|
$ wheneverize .
|
||||||
|
|
||||||
This will create an initial "config/schedule.rb" file you.
|
This will create an initial "config/schedule.rb" file you.
|
||||||
|
|
||||||
== Example schedule.rb file
|
### Example schedule.rb file
|
||||||
|
|
||||||
every 3.hours do
|
every 3.hours do
|
||||||
runner "MyModel.some_process"
|
runner "MyModel.some_process"
|
||||||
rake "my:rake:task"
|
rake "my:rake:task"
|
||||||
command "/usr/bin/my_great_command"
|
command "/usr/bin/my_great_command"
|
||||||
end
|
end
|
||||||
|
|
||||||
every 1.day, :at => '4:30 am' do
|
every 1.day, :at => '4:30 am' do
|
||||||
runner "MyModel.task_to_run_at_four_thirty_in_the_morning"
|
runner "MyModel.task_to_run_at_four_thirty_in_the_morning"
|
||||||
end
|
end
|
||||||
|
|
||||||
every :hour do # Many shortcuts available: :hour, :day, :month, :year, :reboot
|
every :hour do # Many shortcuts available: :hour, :day, :month, :year, :reboot
|
||||||
runner "SomeModel.ladeeda"
|
runner "SomeModel.ladeeda"
|
||||||
end
|
end
|
||||||
|
|
||||||
every :sunday, :at => '12pm' do # Use any day of the week or :weekend, :weekday
|
every :sunday, :at => '12pm' do # Use any day of the week or :weekend, :weekday
|
||||||
runner "Task.do_something_great"
|
runner "Task.do_something_great"
|
||||||
end
|
end
|
||||||
|
|
||||||
More examples on the wiki: http://wiki.github.com/javan/whenever/instructions-and-examples
|
More examples on the wiki: <http://wiki.github.com/javan/whenever/instructions-and-examples>
|
||||||
|
|
||||||
== Define your own job types
|
### Define your own job types
|
||||||
|
|
||||||
Whenever ships with three pre-defined job types: command, runner, and rake. You can define your own with `job_type`.
|
Whenever ships with three pre-defined job types: command, runner, and rake. You can define your own with `job_type`.
|
||||||
|
|
||||||
For example:
|
For example:
|
||||||
|
|
||||||
job_type :awesome, '/usr/local/bin/awesome :task :fun_level'
|
job_type :awesome, '/usr/local/bin/awesome :task :fun_level'
|
||||||
|
|
||||||
every 2.hours do
|
every 2.hours do
|
||||||
awesome "party", :fun_level => "extreme"
|
awesome "party", :fun_level => "extreme"
|
||||||
end
|
end
|
||||||
|
|
||||||
Would run `/usr/local/bin/awesome party extreme` every two hours. `:task` is always replaced with the first argument, and any additional `:whatevers` are replaced with the options passed in or by variables that have been defined with `set`.
|
Would run `/usr/local/bin/awesome party extreme` every two hours. `:task` is always replaced with the first argument, and any additional `:whatevers` are replaced with the options passed in or by variables that have been defined with `set`.
|
||||||
|
|
||||||
The default job types that ship with Whenever are defined like so:
|
The default job types that ship with Whenever are defined like so:
|
||||||
|
|
||||||
job_type :command, ":task :output"
|
job_type :command, ":task :output"
|
||||||
job_type :rake, "cd :path && RAILS_ENV=:environment rake :task :output"
|
job_type :rake, "cd :path && RAILS_ENV=:environment rake :task :output"
|
||||||
job_type :runner, "cd :path && script/runner -e :environment ':task' :output"
|
job_type :runner, "cd :path && script/runner -e :environment ':task' :output"
|
||||||
|
|
||||||
If a script/rails file is detected (like in a Rails 3 app), runner will be defined to fit:
|
If a script/rails file is detected (like in a Rails 3 app), runner will be defined to fit:
|
||||||
|
|
||||||
job_type :runner, "cd :path && script/rails runner -e :environment ':task' :output"
|
job_type :runner, "cd :path && script/rails runner -e :environment ':task' :output"
|
||||||
|
|
||||||
If a `:path` is not set it will default to the directory in which `whenever` was executed. `:environment` will default to 'production'. `:output` will be replaced with your output redirection settings which you can read more about here: http://github.com/javan/whenever/wiki/Output-redirection-(logging-your-cron-jobs)
|
If a `:path` is not set it will default to the directory in which `whenever` was executed. `:environment` will default to 'production'. `:output` will be replaced with your output redirection settings which you can read more about here: <http://github.com/javan/whenever/wiki/Output-redirection-aka-logging-your-cron-jobs>
|
||||||
|
|
||||||
All jobs are by default run with `bash -l -c 'command...'`. Among other things, this allows your cron jobs to play nice with RVM by loading the entire environment instead of cron's somewhat limited environment. Read more: http://blog.scoutapp.com/articles/2010/09/07/rvm-and-cron-in-production
|
All jobs are by default run with `bash -l -c 'command...'`. Among other things, this allows your cron jobs to play nice with RVM by loading the entire environment instead of cron's somewhat limited environment. Read more: <http://blog.scoutapp.com/articles/2010/09/07/rvm-and-cron-in-production>
|
||||||
|
|
||||||
You can change this by setting your own job_template.
|
You can change this by setting your own `:job_template`.
|
||||||
|
|
||||||
set :job_template, "bash -l -c ':job'"
|
set :job_template, "bash -l -c ':job'"
|
||||||
|
|
||||||
Or set the job_template to nil to have your jobs execute normally.
|
Or set the job_template to nil to have your jobs execute normally.
|
||||||
|
|
||||||
set :job_template, nil
|
set :job_template, nil
|
||||||
|
|
||||||
And you'll see your schedule.rb converted to cron sytax. Note: running `whenever` with no options does not display your current crontab file, it simply shows you the output of converting your schedule.rb file.
|
And you'll see your schedule.rb converted to cron sytax. Note: running `whenever` with no options does not display your current crontab file, it simply shows you the output of converting your schedule.rb file.
|
||||||
|
|
||||||
== Capistrano integration
|
### Capistrano integration
|
||||||
|
|
||||||
Use the built-in Capistrano recipe for easy crontab updates with deploys.
|
Use the built-in Capistrano recipe for easy crontab updates with deploys.
|
||||||
|
|
||||||
In your "config/deploy.rb" file:
|
In your "config/deploy.rb" file:
|
||||||
|
|
||||||
require "whenever/capistrano"
|
require "whenever/capistrano"
|
||||||
|
|
||||||
Take a look at the recipe for options you can set. http://github.com/javan/whenever/blob/master/lib/whenever/capistrano.rb
|
Take a look at the recipe for options you can set. <http://github.com/javan/whenever/blob/master/lib/whenever/capistrano.rb>
|
||||||
For example, if you're using bundler do this:
|
For example, if you're using bundler do this:
|
||||||
|
|
||||||
set :whenever_command, "bundle exec whenever"
|
set :whenever_command, "bundle exec whenever"
|
||||||
require "whenever/capistrano"
|
require "whenever/capistrano"
|
||||||
|
|
||||||
== The `whenever` command
|
### The `whenever` command
|
||||||
|
|
||||||
$ cd /my/rails/app
|
$ cd /my/rails/app
|
||||||
$ whenever
|
$ whenever
|
||||||
|
|
||||||
This will simply show you your schedule.rb file converted to cron syntax. It does not read or write your crontab file. Run `whenever --help` for a complete list of options.
|
This will simply show you your schedule.rb file converted to cron syntax. It does not read or write your crontab file. Run `whenever --help` for a complete list of options.
|
||||||
|
|
||||||
== Credit
|
### Credit
|
||||||
|
|
||||||
Whenever was created for use at Inkling (http://inklingmarkets.com) where I work. Their take on it: http://blog.inklingmarkets.com/2009/02/whenever-easy-way-to-do-cron-jobs-from.html
|
Whenever was created for use at Inkling (<http://inklingmarkets.com>) where I work. Their take on it: <http://blog.inklingmarkets.com/2009/02/whenever-easy-way-to-do-cron-jobs-from.html>
|
||||||
|
|
||||||
While building Whenever, I learned a lot by digging through the source code of Capistrano - http://github.com/jamis/capistrano
|
Thanks to all the contributors who have made it even better: <http://github.com/javan/whenever/contributors>
|
||||||
|
|
||||||
== Discussion / Feedback / Issues / Bugs
|
### Discussion / Feedback / Issues / Bugs
|
||||||
|
|
||||||
For general discussion and questions, please use the google group: http://groups.google.com/group/whenever-gem
|
For general discussion and questions, please use the google group: <http://groups.google.com/group/whenever-gem>
|
||||||
|
|
||||||
If you've found a genuine bug or issue, please use the Issues section on github: http://github.com/javan/whenever/issues
|
If you've found a genuine bug or issue, please use the Issues section on github: <http://github.com/javan/whenever/issues>
|
||||||
|
|
||||||
Ryan Bates created a great Railscast about Whenever: http://railscasts.com/episodes/164-cron-in-ruby
|
Ryan Bates created a great Railscast about Whenever: <http://railscasts.com/episodes/164-cron-in-ruby>
|
||||||
It's a little bit dated now, but remains a good introduction.
|
It's a little bit dated now, but remains a good introduction.
|
||||||
|
|
||||||
== License
|
### License
|
||||||
|
|
||||||
Copyright (c) 2009+ Javan Makhmali
|
Copyright (c) 2009+ Javan Makhmali
|
||||||
|
|
Loading…
Reference in New Issue
Block a user