0

Ruby on Railsで遅延ジョブワーカーを開始するための次のスクリプトがあります

require 'rubygems'
require 'daemon_spawn'
$: << '.'

RAILS_ROOT = File.expand_path(File.join(File.dirname(__FILE__), '..'))

class DelayedJobWorker < DaemonSpawn::Base
  def start(args)
    ENV['RAILS_ENV'] ||= args.first || 'development'
    Dir.chdir RAILS_ROOT
    require File.join('config', 'environment')

    Delayed::Worker.new.start
  end

  def stop
    system("kill `cat #{RAILS_ROOT}/tmp/pids/delayed_job.pid`")
  end
end

DelayedJobWorker.spawn!(:log_file => File.join(RAILS_ROOT, "log", "delayed_job.log"),
                    :pid_file => File.join(RAILS_ROOT, 'tmp', 'pids', 'delayed_job.pid'),
                    :sync_log => true,
                    :working_dir => RAILS_ROOT)

このコマンドで始まります

user@mysystem:path/to/my/application$ ruby script/delayed_job start production
DelayedJobWorker started.

crontab で起動時にこの操作を自動化しようとして
います。そのために、このスクリプトを作成しました。

#!/bin/bash
cd path/to/my/application
ruby script/delayed_job start production

これが私のcrontabです

# m h  dom mon dow   command
SHELL=/bin/bash
@reboot /path/to/my/script/delayed_job_at_startup.sh

システムを再起動すると、スクリプトが成功せず、crontab からこのメッセージが表示されます

X-Cron-Env: <SHELL=/bin/bash>
X-Cron-Env: <HOME=/home/finalsayan>
X-Cron-Env: <PATH=/usr/bin:/bin>
X-Cron-Env: <LOGNAME=finalsayan>

/usr/local/rvm/rubies/ruby-1.9.3-p194/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in `require': cannot load such file -- daemon_spawn (LoadError)
    from /usr/local/rvm/rubies/ruby-1.9.3-p194/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in `require'
    from script/delayed_job:24:in `<main>'

ご協力ありがとうございました

4

1 に答える 1

3

問題は、rvm で cron を使用する場合、ドキュメント用に rvm 環境をロードする必要があることでした。 https://rvm.io/integration/cron/を参照してください 。起動時に cron によって呼び出されるスクリプトは次のとおりです。

#!/bin/bash
source /usr/local/rvm/environments/default

# Go to the app
APP_HOME=/path/to/my/application
cd $APP_HOME

# start the delayed jobs
ruby script/delayed_job start production 
于 2012-07-01T16:24:48.240 に答える