Ich habe eine frische Schienen 3 App Entleerung, hier ist mein Gemfile:Delayed_job nicht die Methode ausführen Ausführung aber der Job-Warteschlange
source 'http://rubygems.org'
gem 'rails', '3.0.0' gem 'delayed_job'
gem 'sqlite3-ruby', :require => 'sqlite3'
Hier ist die Klasse ist, die die Arbeit darstellt, die ich in die Warteschlange wollen:
class Me < Struct.new(:something)
def perform
puts "Hello from me"
logger.info "Hello from me"
logger.debug "Hello from me"
raise Exception.new
end
end
der Konsole ohne Arbeiter ausgeführt wird:
irb(main):002:0> Delayed::Job.enqueue Me.new(1)
=> #<Delayed::Backend::ActiveRecord::Job id: 7, priority: 0, attempts: 0, handler: "--- !ruby/struct:Me \nsomething: 1\n", last_error: nil, run_at: "2010-12-29 07:24:11", locked_at: nil, failed_at: nil, locked_by: nil, created_at: "2010-12-29 07:24:11", updated_at: "2010-12-29 07:24:11">
Wie ich schon erwähnt: es gibt keine Arbeiter Laufen:
irb(main):003:0> Delayed::Job.all
=> [#<Delayed::Backend::ActiveRecord::Job id: 7, priority: 0, attempts: 0, handler: "--- !ruby/struct:Me \nsomething: 1\n", last_error: nil, run_at: "2010-12-29 07:24:11", locked_at: nil, failed_at: nil, locked_by: nil, created_at: "2010-12-29 07:24:11", updated_at: "2010-12-29 07:24:11">]
beginne ich einen Arbeiter mit script/delayed_job run
Die Warteschlange geleert wird:
irb(main):006:0> Delayed::Job.all
=> []
jedoch nichts als ein Ergebnis des puts
geschieht, nichts von den logger
Anrufe protokolliert wird, und keine Ausnahme wird ausgelöst. Ich würde jede Hilfe/Einsicht oder irgendetwas zu versuchen schätzen.
Ich habe genau das gleiche Problem. Hast du das jemals gelöst? – Leddo