Class: Resque::Failure::Redis
- Inherits:
-
Base
- Object
- Base
- Resque::Failure::Redis
show all
- Defined in:
- lib/resque/failure/redis.rb
Overview
A Failure backend that stores exceptions in Redis. Very simple but works out of the box, along with support in the Resque web app.
Instance Attribute Summary
Attributes inherited from Base
#exception, #payload, #queue, #worker
Class Method Summary
collapse
Instance Method Summary
collapse
Methods inherited from Base
#initialize, #log, url
Class Method Details
.all(start = 0, count = 1) ⇒ Object
24
25
26
|
# File 'lib/resque/failure/redis.rb', line 24
def self.all(start = 0, count = 1)
Resque.list_range(:failed, start, count)
end
|
.clear ⇒ Object
28
29
30
|
# File 'lib/resque/failure/redis.rb', line 28
def self.clear
Resque.redis.del(:failed)
end
|
.count ⇒ Object
20
21
22
|
# File 'lib/resque/failure/redis.rb', line 20
def self.count
Resque.redis.llen(:failed).to_i
end
|
.requeue(index) ⇒ Object
32
33
34
35
36
37
|
# File 'lib/resque/failure/redis.rb', line 32
def self.requeue(index)
item = all(index)
item['retried_at'] = Time.now.strftime("%Y/%m/%d %H:%M:%S")
Resque.redis.lset(:failed, index, Resque.encode(item))
Job.create(item['queue'], item['payload']['class'], *item['payload']['args'])
end
|
Instance Method Details
#save ⇒ Object
6
7
8
9
10
11
12
13
14
15
16
17
18
|
# File 'lib/resque/failure/redis.rb', line 6
def save
data = {
:failed_at => Time.now.strftime("%Y/%m/%d %H:%M:%S"),
:payload => payload,
:exception => exception.class.to_s,
:error => exception.to_s,
:backtrace => exception.backtrace,
:worker => worker.to_s,
:queue => queue
}
data = Resque.encode(data)
Resque.redis.rpush(:failed, data)
end
|