2

我有一些在高峰时段运行时间超过 119 秒的作业,并且当它出现时,我不断收到下面的跟踪错误。我正在使用stalker,beanstalkdclockwork我的后台处理。在哪里/如何更改超时设置?

Exception Stalker::JobTimeout -> find.products hit 119s timeout
   /home/blake/.rvm/gems/ruby-1.9.2-p180/gems/stalker-0.9.0/lib/stalker.rb:86:in
4

1 回答 1

3

Stalker.enqueue 有 3 个选项:作业名称字符串、参数散列、选项散列。

选项哈希可以采用键/值对:ttr => timeout_in_seconds,正如您可能猜到的那样,它设置了 Stalker 在引发 JobTimeout 异常之前允许的秒数。

例如,如果你有一些疯狂的计算,你预计需要一个小时:

#job code
job 'crazy.calculation' do |args|
  args['x'].to_i + args['y'].to_i + args['z'].to_i
end

#queuing code
Stalker.enqueue 'crazy.calculation', {:x => 1, :y => 2, :z => 3}, {:ttr => 3600}

如果您的计算不带参数,则使用相同的代码

#job code
job 'crazy.calculation' do |args|
  1 + 2 + 3
end

#queuing code
Stalker.enqueue 'crazy.calculation', {}, {:ttr => 3600}

不要对 enqueue args 散列和作业 args 散列中的符号和字符串的可互换性感到困惑,在选项散列中:ttr 必须是符号。

于 2011-07-08T00:33:22.490 回答