遅延ジョブの完了率を表示するソリューションに取り組んでいます (delayed_job gem を使用)。現在、delayed_jobs テーブルに対して次のようなデータベース移行があります。
class CreateDelayedJobs < ActiveRecord::Migration
def self.up
create_table :delayed_jobs, :force => true do |table|
table.integer :priority, :default => 0 # Allows some jobs to jump to the front of the queue
table.integer :attempts, :default => 0 # Provides for retries, but still fail eventually.
table.text :handler # YAML-encoded string of the object that will do work
table.text :last_error # reason for last failure (See Note below)
table.datetime :run_at # When to run. Could be Time.zone.now for immediately, or sometime in the future.
table.datetime :locked_at # Set when a client is working on this object
table.datetime :failed_at # Set when all retries have failed (actually, by default, the record is deleted instead)
table.string :locked_by # Who is working on this object (if locked)
table.string :queue # The name of the queue this job is in
table.integer :progress
table.timestamps
end
add_index :delayed_jobs, [:priority, :run_at], :name => 'delayed_jobs_priority'
end
def self.down
drop_table :delayed_jobs
end
end
遅延ジョブのコントローラー メソッド内でエンキュー プロセスを使用し、 lib/build_detail.rb 内のクラスを参照しています。
Delayed::Job.enqueue(BuildDetail.new(@object, @com))
lib/build_detail.rb ファイルは次のとおりです。
class BuildDetail < Struct.new(:object, :com)
def perform
total_count = object.person_ids.length
progress_count = 0
people = com.person object.person_ids do |abc|
progress_count += abc.size
Delayed::Job.current.update_attribute :progress, (progress_count/total_count)
end
end
end
Delayed::Job.current が機能しません。この投稿で提案された Delayed::Job.current メソッドを見ましたが、このメソッドはメインのdelayed_jobs github プロジェクトには含まれていないようです。
現在のジョブに (実際のジョブ内から) アクセスして、ジョブがループするたびに進行状況フィールドを更新するにはどうすればよいですか?