Rails cron whenever, bundle: command not found

Ruby on-RailsCronWhenever

Ruby on-Rails Problem Overview


I am trying to use whenever to execute a rake task onces a day. Im getting this error

/bin/bash: bundle: command not found
/home/app/.rvm/rubies/ruby-1.9.2-p180/lib/ruby/site_ruby/1.9.1/rubygems/dependency.rb:247:in `to_specs': Could not find bundler (>= 0) amongst [minitest-1.6.0, rake-0.8.7, rdoc-2.5.8] (Gem::LoadError)
    	from /home/app/.rvm/rubies/ruby-1.9.2-p180/lib/ruby/site_ruby/1.9.1/rubygems/dependency.rb:256:in `to_spec'
    	from /home/app/.rvm/rubies/ruby-1.9.2-p180/lib/ruby/site_ruby/1.9.1/rubygems.rb:1210:in `gem'
    	from /home/app/.rvm/gems/ruby-1.9.2-p180/bin/bundle:18:in `<main>'

Here is my crontab

# Begin Whenever generated tasks for: /home/af/www/app/releases/20120216172204/config/schedule.rb
PATH=/home/af/.rvm/gems/ruby-1.9.2-p180@global/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games

0 0 * * * /bin/bash -l -c 'cd /home/af/www/app/releases/20120216172204 && rvm 1.9.1-p180; RAILS_ENV=production /home/af/.rvm/gems/ruby-1.9.2-p180/bin/bundle exec rake daily:stats --silent >> /home/af/www/app/releases/20120216172204/log/cron.log 2>&1'

# End Whenever generated tasks for: /home/af/www/app/releases/20120216172204/config/schedule.rb

I'm at a loss as to why it isn't working. If I run the command:

cd /home/af/www/app/releases/20120216172204 && rvm 1.9.1-p180; RAILS_ENV=production /home/af/.rvm/gems/ruby-1.9.2-p180/bin/bundle exec rake daily:stats --silent >> /home/af/www/app/releases/20120216172204/log/cron.log 2>&1

It works fine, not sure whats going on here.

Ruby on-Rails Solutions


Solution 1 - Ruby on-Rails

You can also ensure your PATH ends up in the crontab, by putting the following at the top of the schedule.rb file:

env :PATH, ENV['PATH']

https://groups.google.com/forum/#!msg/whenever-gem/yRLt3f2jrfU/Exu3xfCo8DAJ

If above solution don't work for you, try:

env :GEM_PATH, ENV['GEM_PATH']

Solution 2 - Ruby on-Rails

In my case I just ran :

rvm env --path -- ruby-version[@gemset-name]

Referring to cron job setup doc

Added new source line to the command for ruby path before bundle command in the crontab -e

source /usr/local/rvm/environments/ruby-1.9.3-p392;

Now the commands like as below:

Before:

0 4 * * * cd /home/current && bundle exec rake my_rake RAILS_ENV=production

After:

0 4 * * * cd /home/current && source /usr/local/rvm/environments/ruby-1.9.3-p392; bundle exec rake my_rake RAILS_ENV=production

Cheers!!!

Solution 3 - Ruby on-Rails

After so many try outs the following seems to work

Type the following from terminal

  1. Type crontab -e This opens the crontab for editing. You will see two lines as below:

    cron clears out environment variables, but Rubber.root/script/rubber uses

    "rvm do default" to run, so no longer any need to setup ruby env vars here,

    all we need is PATH

    PATH=//bundle/ruby/1.9.1/bin:/usr/local/rvm/gems

AND
    # Begin Whenever generated tasks for: /mnt/wamjoke-production/releases/20120912$
    PATH=/<path to bundle>/shared/bundle/ruby/1.9.1/bin:/usr/local/rvm/gems

2. Comment out both lines beginning with PATH.

Do the above step whenever you run "bundle exec whenever" command. And it works.

No idea why PATH is misleading the environment.

Solution 4 - Ruby on-Rails

I hate this problem - I've spent hours trying to solve it too.

What works for me is to add

RAILS_ENV=production; source /usr/local/rvm/scripts/rvm;

before the bundle command.

Solution 5 - Ruby on-Rails

Forget about PATH settings in cron files. Setting the PATH does not work.

Set the path to bundle explicitly in your config/schedule.rb

set :bundle_command, "/usr/local/bin/bundle"

Solution 6 - Ruby on-Rails

I think you should try explicitly setting the GEM_HOME and GEM_PATH environment variables in your crontab. You could also try running something like gem list --local or gem environment through cron and checking the output.

Solution 7 - Ruby on-Rails

I played around with this all afternoon and couldn't find a better solution. Here is what I have come up with

bundle install --binstubs

and then run

bin/rake daily:stats

Solution 8 - Ruby on-Rails

You can try below solution which I found while googling and that works for me finally....hope that should work with you.

I implemented and tested the same on production make sure that to change environment accordingly -

set :output, "{your path on the server}/log/cron_log.log"
 set :environment, :production
 env :PATH, ENV['PATH']
 job_type :rbenv_rake, %q!eval "$(rbenv init -)"; cd :path && :environment_variable=:environment bundle exec rake :task --silent :output!

Best luck, This issue occurred after 3 years as I was using before just simple what given on the gem documentation on production.

I'm using Ruby 2.x and Rails 4.2 with whenever 0.9.4 latest version. It should work with earlier version as well, if the nature of the issue is same.

thank you.

Solution 9 - Ruby on-Rails

By executing a command that way: /bin/bash -l -c

You are launching a bash command as a login shell which is going to source (execute) /etc/profile bash file as a setup file. By doing so, if you check this file, it might have bash command lines that erase your previous $PATH which you do not want to since it contains your path to your bundle and all your other commands in the first place.

To fix this issue you just have to remove the lines related to set up the $PATH variable in your /etc/profile file.

Solution 10 - Ruby on-Rails

This is a ENV['PATH'] not set issue. The most elegant way to fix this is to append the rvm related scripts to the path right after the install. Add the following lines to beginning of .bashrc ( beginning and not end as when .bashrc is accessed by a non-interactive shell, the line [ -z "$PS1" ] && return throws error and the subsequent lines are not executed.

PATH=$PATH:$HOME/.rvm/bin # Add RVM to PATH for scripting
[[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm"

and not try to explicitly set PATH and sully environment variables.

Solution 11 - Ruby on-Rails

For those using rbenv you can use the included shim /home/username/.rbenv/shims/bundle

0 0 * * * /bin/bash -l -c 'cd /home/af/www/app/releases/20120216172204 && RAILS_ENV=production /home/af/.rbenv/shims/bundle exec rake daily:stats --silent >> /home/af/www/app/releases/20120216172204/log/cron.log 2>&1'

Solution 12 - Ruby on-Rails

in 2021, I found a basic solution, just add on top of schedule.rb

 env :PATH, ENV['PATH']
 set :output, "log/cron_log.log"
 set :runner_command, "rails runner"

from:

https://github.com/javan/whenever/issues/665

Solution 13 - Ruby on-Rails

I solved this problem by printing out my environmental variables

printenv

finding the ones that look related to Rails. One was a path to gems, the other was GEM_HOME and prepending the command in cron with these two:

PATH=$PATH:/home/petr/gems/bin GEM_HOME=/home/petr/gems program_executable

Solution 14 - Ruby on-Rails

Also in 2021, adding this in schedule.rb worked for me:

set :job_template, "bash -l -c 'PATH=#{ENV['PATH']} && :job'"

> All jobs are by default run with bash -l -c 'command...' (https://github.com/javan/whenever)

So I made bash include ENV['PATH'] in PATH at the beginning and now rails are called from the proper rbenv.

Solution 15 - Ruby on-Rails

For modern fix, add this line in capistrano deploy.rb,

set :whenever_command, "bundle exec whenever"

Solution 16 - Ruby on-Rails

[root@smbserver current]# crontab -e

02 22 * * 1-5 /bin/bash -l -c  /shell/day.sh 
30 14 * * 0 /bin/bash -l -c  /shell/week.sh 

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionJosh CrowderView Question on Stackoverflow
Solution 1 - Ruby on-RailsDennis KuczynskiView Answer on Stackoverflow
Solution 2 - Ruby on-RailsSumit MunotView Answer on Stackoverflow
Solution 3 - Ruby on-RailsbuddyView Answer on Stackoverflow
Solution 4 - Ruby on-RailscailinanneView Answer on Stackoverflow
Solution 5 - Ruby on-RailsvanboomView Answer on Stackoverflow
Solution 6 - Ruby on-RailsSebiView Answer on Stackoverflow
Solution 7 - Ruby on-RailsJosh CrowderView Answer on Stackoverflow
Solution 8 - Ruby on-RailsRameshwar VyevhareView Answer on Stackoverflow
Solution 9 - Ruby on-RailsaxzwlView Answer on Stackoverflow
Solution 10 - Ruby on-RailsLavixuView Answer on Stackoverflow
Solution 11 - Ruby on-RailsDexView Answer on Stackoverflow
Solution 12 - Ruby on-RailsAnnABlueView Answer on Stackoverflow
Solution 13 - Ruby on-RailspkoutView Answer on Stackoverflow
Solution 14 - Ruby on-RailsPierekEastView Answer on Stackoverflow
Solution 15 - Ruby on-RailschagelView Answer on Stackoverflow
Solution 16 - Ruby on-RailsiceskyslView Answer on Stackoverflow