【发布时间】:2026-01-08 05:40:01
【问题描述】:
我遇到了这个运行时错误:
11843:E, [2015-05-13T11:00:00.467150 #9464] ERROR -- : 2015-05-13T11:00:00-0400: [Worker(delayed_job host:server pid:9464)] Job CronJob (id=5550d0f84d6f747bcb000000) FAILED with **NoMethodError: undefined method `loadData' for AdminController:Class**
如何从 cronJob 类中调用方法 loadData()?我使用控制台测试代码,如果我从控制台调用它可以正常工作:AdminController.new.loadData()
class AdminController < ApplicationController
...
def setLoadSchedule
logger.debug "set hour #{params[:admin][:hour]}"
sethour = params[:admin][:hour]
Delayed::Job.find(Perseus::Application.config.delayed_job_id).destroy if Perseus::Application.config.delayed_job_id != :nil
Perseus::Application.config.delayed_job_id = Delayed::Job.enqueue(CronJob.new, cron: '0 ' << sethour << ' * * 1-5')
hide_action :loadData
def loadData()
...
end
private
def isAdmin
if !current_user.admin
redirect_to root_path
end
end
end
class CronJob < Struct.new("CronJob")
def perform
AdminController.new.loadData()
end
end
【问题讨论】:
标签: ruby ruby-on-rails-4 delayed-job