tootsie 0.9.16 → 0.9.17

Sign up to get free protection for your applications and to get access to all the features.
data/README.md CHANGED
@@ -177,6 +177,8 @@ Current limitations
177
177
 
178
178
  * Transcoding options are very basic.
179
179
  * No client access control; anyone can submit jobs.
180
+ * SQS: Due to limitations in the `sqs` gem, only US queues may be used at the moment.
181
+ * AMQP adapter does not support measuring the queue length at the moment.
180
182
 
181
183
  Requirements
182
184
  ============
@@ -244,6 +246,38 @@ Jobs may now be posted to the web service API. For example:
244
246
  }
245
247
  END
246
248
 
249
+ Configuration
250
+ =============
251
+
252
+ The configuration is a YAML document with the following keys:
253
+
254
+ aws_access_key_id: <your Amazon key>
255
+ aws_secret_access_key: <your Amazon secret>
256
+ pid_path: <where to write pid file>
257
+ log_path: <where to write log file>
258
+ worker_count: <number of workers>
259
+ queue:
260
+ <... queue options ...>
261
+
262
+ The queue options is a hash with a key `adapter` telling Tootsie which queue implementation to use.
263
+
264
+ The `sqs` adapter takes the following options:
265
+
266
+ queue_name: <name of queue, defaults to 'tootsie'>
267
+ max_backoff: <max seconds to wait when queue is empty, defaults to 2>
268
+
269
+ For the `amqp` adapter:
270
+
271
+ queue_name: <name of queue, defaults to 'tootsie'>
272
+ host_name: <host name of AMQP server, defaults to localhost>
273
+ max_backoff: <max seconds to wait when queue is empty, defaults to 2>
274
+
275
+ For the `file` adapter:
276
+
277
+ root: <directory to store files>
278
+
279
+ Note that when running a large number of workers, you should increase the backoff interval to avoid incurring a lot of queue requests.
280
+
247
281
  License
248
282
  =======
249
283
 
@@ -26,13 +26,15 @@ module Tootsie
26
26
  case adapter
27
27
  when 'sqs'
28
28
  @queue = Tootsie::SqsQueue.new(
29
- queue_options[:queue],
30
- @configuration.aws_access_key_id,
31
- @configuration.aws_secret_access_key)
29
+ :queue_name => queue_options[:queue],
30
+ :access_key_id => @configuration.aws_access_key_id,
31
+ :secret_access_key => @configuration.aws_secret_access_key,
32
+ :max_backoff => queue_options[:max_backoff])
32
33
  when 'amqp'
33
34
  @queue = Tootsie::AmqpQueue.new(
34
- queue_options[:host],
35
- queue_options[:queue])
35
+ :host_name => queue_options[:host],
36
+ :queue_name => queue_options[:queue],
37
+ :max_backoff => queue_options[:max_backoff])
36
38
  when 'file'
37
39
  @queue = Tootsie::FileSystemQueue.new(queue_options[:root])
38
40
  else
@@ -3,10 +3,13 @@ module Tootsie
3
3
  # A queue which uses the AMQP protocol.
4
4
  class AmqpQueue
5
5
 
6
- def initialize(host_name, queue_name)
6
+ def initialize(options = {})
7
+ options.assert_valid_keys(:host_name, :queue_name, :max_backoff)
7
8
  @logger = Application.get.logger
8
- @host_name = host_name || 'localhost'
9
- @queue_name = queue_name || 'tootsie'
9
+ @host_name = options[:host_name] || 'localhost'
10
+ @queue_name = options[:queue_name] || 'tootsie'
11
+ @max_backoff = (options[:max_backoff] || 2).to_f
12
+ @backoff = 0.0
10
13
  connect!
11
14
  end
12
15
 
@@ -61,7 +64,7 @@ module Tootsie
61
64
  @backoff /= 2.0
62
65
  return result
63
66
  else
64
- @backoff = [@backoff * 1.1, 1.0].min
67
+ @backoff = [@backoff * 1.1, @max_backoff].min
65
68
  @logger.info "Backing off #{@backoff}"
66
69
  sleep(@backoff)
67
70
  end
@@ -9,27 +9,30 @@ module Tootsie
9
9
  # A queue which uses Amazon's Simple Queue Service (SQS).
10
10
  class SqsQueue
11
11
 
12
- def initialize(queue_name, access_key_id, secret_access_key)
12
+ def initialize(options)
13
+ options.assert_valid_keys(:access_key_id, :secret_access_key, :queue_name, :max_backoff)
13
14
  @sqs_service = ::Sqs::Service.new(
14
- :access_key_id => access_key_id,
15
- :secret_access_key => secret_access_key)
15
+ :access_key_id => options[:access_key_id],
16
+ :secret_access_key => options[:secret_access_key])
16
17
  @logger = Application.get.logger
17
- @queue = @sqs_service.queues.find_first(queue_name)
18
+ @queue_name = options[:queue_name] || 'tootsie'
19
+ @queue = @sqs_service.queues.find_first(@queue_name)
18
20
  unless @queue
19
- @logger.info "Queue #{queue_name} does not exist, creating it"
20
- @sqs_service.queues.create(queue_name)
21
+ @logger.warn "Queue #{@queue_name} does not exist, creating it"
22
+ @sqs_service.queues.create(@queue_name)
21
23
  begin
22
24
  timeout(30) do
23
25
  while not @queue
24
26
  sleep(1)
25
- @queue = @sqs_service.queues.find_first(queue_name)
27
+ @queue = @sqs_service.queues.find_first(@queue_name)
26
28
  end
27
29
  end
28
30
  rescue Timeout::Error
29
31
  raise SqsQueueCouldNotFindQueueError
30
32
  end
31
33
  end
32
- @backoff = 0.5
34
+ @max_backoff = (options[:max_backoff] || 2).to_f
35
+ @backoff = 0.0
33
36
  end
34
37
 
35
38
  def count
@@ -76,7 +79,7 @@ module Tootsie
76
79
  @backoff /= 2.0
77
80
  break
78
81
  else
79
- @backoff = [@backoff * 0.2, 2.0].min
82
+ @backoff = [@backoff * 0.2, @max_backoff].min
80
83
  end
81
84
  break unless options[:wait]
82
85
  sleep(@backoff)
@@ -1,3 +1,3 @@
1
1
  module Tootsie
2
- VERSION = '0.9.16'
2
+ VERSION = '0.9.17'
3
3
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: tootsie
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.9.16
4
+ version: 0.9.17
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -13,7 +13,7 @@ date: 2012-01-24 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: json
16
- requirement: &70283191457260 !ruby/object:Gem::Requirement
16
+ requirement: &70200327586920 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ~>
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: 1.4.6
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *70283191457260
24
+ version_requirements: *70200327586920
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: sinatra
27
- requirement: &70283191456740 !ruby/object:Gem::Requirement
27
+ requirement: &70200327586400 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ~>
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '1.0'
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *70283191456740
35
+ version_requirements: *70200327586400
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: activesupport
38
- requirement: &70283191456260 !ruby/object:Gem::Requirement
38
+ requirement: &70200327585920 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ~>
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: 3.0.0
44
44
  type: :runtime
45
45
  prerelease: false
46
- version_requirements: *70283191456260
46
+ version_requirements: *70200327585920
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: httpclient
49
- requirement: &70283191455780 !ruby/object:Gem::Requirement
49
+ requirement: &70200327585440 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ~>
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: 2.2.1
55
55
  type: :runtime
56
56
  prerelease: false
57
- version_requirements: *70283191455780
57
+ version_requirements: *70200327585440
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: builder
60
- requirement: &70283191455300 !ruby/object:Gem::Requirement
60
+ requirement: &70200327584960 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ~>
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: 2.1.2
66
66
  type: :runtime
67
67
  prerelease: false
68
- version_requirements: *70283191455300
68
+ version_requirements: *70200327584960
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: mime-types
71
- requirement: &70283191454820 !ruby/object:Gem::Requirement
71
+ requirement: &70200327584480 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ~>
@@ -76,10 +76,10 @@ dependencies:
76
76
  version: '1.16'
77
77
  type: :runtime
78
78
  prerelease: false
79
- version_requirements: *70283191454820
79
+ version_requirements: *70200327584480
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: xml-simple
82
- requirement: &70283191454340 !ruby/object:Gem::Requirement
82
+ requirement: &70200327584000 !ruby/object:Gem::Requirement
83
83
  none: false
84
84
  requirements:
85
85
  - - ~>
@@ -87,10 +87,10 @@ dependencies:
87
87
  version: 1.0.12
88
88
  type: :runtime
89
89
  prerelease: false
90
- version_requirements: *70283191454340
90
+ version_requirements: *70200327584000
91
91
  - !ruby/object:Gem::Dependency
92
92
  name: thin
93
- requirement: &70283191453860 !ruby/object:Gem::Requirement
93
+ requirement: &70200327583520 !ruby/object:Gem::Requirement
94
94
  none: false
95
95
  requirements:
96
96
  - - ~>
@@ -98,10 +98,10 @@ dependencies:
98
98
  version: 1.2.7
99
99
  type: :runtime
100
100
  prerelease: false
101
- version_requirements: *70283191453860
101
+ version_requirements: *70200327583520
102
102
  - !ruby/object:Gem::Dependency
103
103
  name: s3
104
- requirement: &70283191453380 !ruby/object:Gem::Requirement
104
+ requirement: &70200327583040 !ruby/object:Gem::Requirement
105
105
  none: false
106
106
  requirements:
107
107
  - - ~>
@@ -109,10 +109,10 @@ dependencies:
109
109
  version: 0.3.8
110
110
  type: :runtime
111
111
  prerelease: false
112
- version_requirements: *70283191453380
112
+ version_requirements: *70200327583040
113
113
  - !ruby/object:Gem::Dependency
114
114
  name: bunny
115
- requirement: &70283191452900 !ruby/object:Gem::Requirement
115
+ requirement: &70200327582560 !ruby/object:Gem::Requirement
116
116
  none: false
117
117
  requirements:
118
118
  - - ~>
@@ -120,10 +120,10 @@ dependencies:
120
120
  version: 0.7.8
121
121
  type: :runtime
122
122
  prerelease: false
123
- version_requirements: *70283191452900
123
+ version_requirements: *70200327582560
124
124
  - !ruby/object:Gem::Dependency
125
125
  name: sqs
126
- requirement: &70283201355500 !ruby/object:Gem::Requirement
126
+ requirement: &70200327582080 !ruby/object:Gem::Requirement
127
127
  none: false
128
128
  requirements:
129
129
  - - ~>
@@ -131,10 +131,10 @@ dependencies:
131
131
  version: 0.1.2
132
132
  type: :runtime
133
133
  prerelease: false
134
- version_requirements: *70283201355500
134
+ version_requirements: *70200327582080
135
135
  - !ruby/object:Gem::Dependency
136
136
  name: unicorn
137
- requirement: &70283201355020 !ruby/object:Gem::Requirement
137
+ requirement: &70200327581600 !ruby/object:Gem::Requirement
138
138
  none: false
139
139
  requirements:
140
140
  - - ~>
@@ -142,10 +142,10 @@ dependencies:
142
142
  version: 4.1.1
143
143
  type: :runtime
144
144
  prerelease: false
145
- version_requirements: *70283201355020
145
+ version_requirements: *70200327581600
146
146
  - !ruby/object:Gem::Dependency
147
147
  name: i18n
148
- requirement: &70283201354540 !ruby/object:Gem::Requirement
148
+ requirement: &70200327581120 !ruby/object:Gem::Requirement
149
149
  none: false
150
150
  requirements:
151
151
  - - ! '>='
@@ -153,10 +153,10 @@ dependencies:
153
153
  version: 0.4.2
154
154
  type: :runtime
155
155
  prerelease: false
156
- version_requirements: *70283201354540
156
+ version_requirements: *70200327581120
157
157
  - !ruby/object:Gem::Dependency
158
158
  name: scashin133-syslog_logger
159
- requirement: &70283201354060 !ruby/object:Gem::Requirement
159
+ requirement: &70200327580640 !ruby/object:Gem::Requirement
160
160
  none: false
161
161
  requirements:
162
162
  - - ~>
@@ -164,10 +164,10 @@ dependencies:
164
164
  version: 1.7.3
165
165
  type: :runtime
166
166
  prerelease: false
167
- version_requirements: *70283201354060
167
+ version_requirements: *70200327580640
168
168
  - !ruby/object:Gem::Dependency
169
169
  name: rspec
170
- requirement: &70283201353680 !ruby/object:Gem::Requirement
170
+ requirement: &70200327580260 !ruby/object:Gem::Requirement
171
171
  none: false
172
172
  requirements:
173
173
  - - ! '>='
@@ -175,10 +175,10 @@ dependencies:
175
175
  version: '0'
176
176
  type: :development
177
177
  prerelease: false
178
- version_requirements: *70283201353680
178
+ version_requirements: *70200327580260
179
179
  - !ruby/object:Gem::Dependency
180
180
  name: rake
181
- requirement: &70283201353220 !ruby/object:Gem::Requirement
181
+ requirement: &70200327579800 !ruby/object:Gem::Requirement
182
182
  none: false
183
183
  requirements:
184
184
  - - ! '>='
@@ -186,7 +186,7 @@ dependencies:
186
186
  version: '0'
187
187
  type: :development
188
188
  prerelease: false
189
- version_requirements: *70283201353220
189
+ version_requirements: *70200327579800
190
190
  description: Tootsie is a simple audio/video/image transcoding/modification application.
191
191
  email:
192
192
  - alex@origo.no