每当在Docker容器中的Rails应用程序中的cronjob不工作时

时间:2017-08-23 07:23:49

标签: ruby-on-rails docker whenever

每当在docker容器内时,我都会设置一个cronjob。 一切看起来都很好,但它不起作用。

这是我的代码的一部分。

的Gemfile:

gem 'whenever', :require => false

配置/ schedule.rb

set :output, "log/cron.log"
env :PATH, ENV['PATH']
set :environment, 'development'

every 1.day, :at => '1:00 am' do
  rake "import"
end

every 1.minute do
  p "#{Time.now}!"
  rake "cron_test"
end

我的dockerfile

RUN apt-get update -qq && apt-get install -y build-essential libpq-dev cron postgresql-client-9.4 dos2unix
RUN touch $APP_HOME/log/cron.log
RUN bundle exec whenever --update-crontab
CMD cron && bundle exec puma

当我运行whenever时,我得到了

PATH=/usr/local/bundle/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

0 1 * * * /bin/bash -l -c 'cd /mlcot && RAILS_ENV=development bundle exec rake import --silent >> log/cron.log 2>&1'

* * * * * /bin/bash -l -c 'cd /mlcot && RAILS_ENV=development bundle exec rake cron_test --silent >> log/cron.log 2>&1'

## [message] Above is your schedule file converted to cron syntax; your crontab file was not updated.
## [message] Run `whenever --help' for more options.

我可以从谷歌找到任何检查,但仍然没有发生任何事情。我甚至没有得到log/cron.log档。

但如果我直接跑 /bin/bash -l -c 'cd /mlcot && RAILS_ENV=development bundle exec rake cron_test --silent'

有效。任何建议或建议将不胜感激。

1 个答案:

答案 0 :(得分:2)

我通过添加它来解决它。

Dockfile:

RUN gem install bundler --version 1.11.2

# another line

CMD cron -f && bundle exec puma

并将此行添加到schedule.rb

ENV.each { |k, v| env(k, v) }

感谢herehere