Работник Resque выдает «NoMethodError: неопределенный метод` execute` » - PullRequest
6 голосов
/ 25 октября 2010

Я понятия не имею, что я здесь сделал, но я попытался заставить один контроллер в Rails поставить задачу в очередь на Resque, к которой затем рабочий подключается и выполняет тяжелую работу (сравнения IE, записи в базе данных).
Однако задачи даже не выполняются, поскольку нет четких инструкций по настройке Resque up.

Ниже приведены копии и вставки:
Также доступно в формате Gist!

Это строка исключения из Hoptoad:

NoMethodError: undefined method 'perform' for Violateq:Module

Это содержимое файла «worker»:

module Violateq
  @queue = :violateq

  def perform(nick, rulenumber)
    # Working for the weekend!!!
    puts "I got a nick of #{nick} and they broke #{rulenumber}"
    @violation = Violation.new(nick, rulenumber)
    puts "If you got this far, your OK"
    log_in(:worker_log, {:action => "Violate d=perfom", :nick => nick, :rulenumber => rulenumber, :status => "success"})
    #rescue => ex
    # notify_hoptoad(ex)
    # log_in(:worker_log, {:action => "Violate d=perfom", :nick => nick, :rulenumber => rulenumber, :status => "failure"})
  end

end

Это содержимое «web_controller»file:

class IncomingController < ApplicationController
  require 'mail'
  skip_before_filter :verify_authenticity_token

  def create
    message = Mail.new(params[:message])
    # Push the message into the queue
    Resque.enqueue(Violateq, message.from.to_s, message.subject.to_s)
    log_in(:endpoint_log, {:action => "IncomingController d=create", :subject => message.subject, :message => message.body.decoded})
    render :text => 'success', :status => 200 # a status of 404 would reject the mail
  rescue => ex
      notify_hoptoad(ex)
      render :text => 'failure', :status => 500
  end
end

Большое спасибо за ваше время, и если вам нужна дополнительная информация, пожалуйста, не стесняйтесь связаться со мной,
Luke Carpenter

1 Ответ

16 голосов
/ 27 октября 2010

Исправлено.
Изменено def perform на def self.perform
Тогда это сработало

Спасибо
Люк Карпентер

...