更新红宝石后,crontab无法正常工作“捆绑器:不可执行:bin / rails”

时间:2019-04-25 10:44:06

标签: ruby-on-rails ruby cron rbenv whenever

将ruby版本从2.3.1更新到2.3.7之后,crontab在生产环境中不可执行(在本地环境中工作)。在更新之前,它一直在工作。

我正在使用rbenv,因此我可以在Internet上找到的解决此类问题的信息($ rvm cron安装程序)不适合我的情况。

schedule.rb代码为:

env :PATH, ENV['PATH']
env :GEM_PATH, ENV['GEM_PATH']
rails_env = ENV['RAILS_ENV'] || :development
require File.expand_path(File.dirname(__FILE__) + "/environment")
set :environment, rails_env
set :output, "#{Rails.root}/log/cron.log"

 every 1.day do
  runner "Reminder.reminder_mail"
end

奇怪的是,红宝石版本显示

$ ruby -v
ruby 2.3.7p456 (2018-03-28 revision 63024) [x86_64-linux]

但是环境显示的红宝石版本不同。

$ bundle env
Ruby          2.3.1p112 (2016-04-26 revision 0) [x86_64-linux-gnu]

我不知道这是不是一个问题以及如何解决。

crontab的当前设置为:

$ crontab -l
PATH=/home/franky/list/voendor/bundler/ruby/2.3.0/bin:/usr/local/bin:/home/franky/.gem/ruby/2.3.0/bin:/usr/local/rbenv/shims:~/.rbenv/shims:/usr/local/rbenv/bin:/usr/local/sbin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
GEM_PATH=””

0 0 * * * /bin/bash -l -c ‘cd /home/franky/list && bundle exec bin/rails runner -e production ‘'‘Reminder.reminder_mail’'’ » /home/franky/list/log/cron.log 2>&1’

有人可以帮我解决这个问题吗?

1 个答案:

答案 0 :(得分:0)

我可以使用“ rake db:drop”和“ rake db:create”解决此问题!!! crontab再次正常工作!