This is an Amazon SQS backend for delayed_job
To start using delayed_job_sqs, you need to sign up for an AWS account and setup your credentials.
- Go to https://portal.aws.amazon.com/gp/aws/developer/registration/index.html and sign up.
- Get your AWS Access Key Id & Secret Access Key for your account.
- Either
require 'aws-sdk'
and callAWS.config()
prior torequire 'delayed_job_sqs'
, or create an aws.yml that will get loaded with your app. You will need to configure Delayed::Worker below to pass in the YAML file location:
[aws]
access_key_id: <your access key>
secret_access_key: <your secret key>
Or if using Rails, create config/initializers/aws-sdk.rb and put the following into the file:
AWS.config({
access_key_id: '<your access key>',
secret_access_key: '<your secret key>',
})
Add the gems to your Gemfile:
gem 'delayed_job'
gem 'delayed_job_sqs'
Optionally: Add an initializer (config/initializers/delayed_job.rb
):
Delayed::Worker.configure do |config|
# optional params:
config.aws_config = '~/stuff/things/aws.yml' # Specify the file location of the AWS configuration YAML if you're not using Rails and you want to use a YAML file instead of calling AWS.config
config.default_queue_name = 'default' # Specify an alternative default queue name
config.delay_seconds = # Sets the default delay in seconds for messages sent to the queue.
config.message_retention_period = 345600 # The number of seconds Amazon SQS retains a message. Must be an integer from 3600 (1 hour) to 1209600 (14 days). The default for this attribute is 345600 (4 days).
config.visibility_timeout = 30 # The length of time (in seconds) that a message received from a queue will be invisible to other receiving components when they ask to receive messages. Valid values: integers from 0 to 43200 (12 hours).
config.wait_time_seconds = # How many seconds to wait for a response
end
That's it. Use delayed_job as normal.
Example:
class User
def background_stuff
puts "I run in the background"
end
end
Then in one of your controllers:
user = User.new
user.delay.background_stuff
You can send multiple messages to SQS in a single request by using:
Delayed::Job.start_buffering!
Once you want to stop buffering, simply use:
Delayed::Job.stop_buffering!
Ensure that messages are sent by persisting the messages at the end of your transaction:
Delayed::Job.persist_buffer!
This clears the buffer once the messages are sent.
Finally, you may explicitly clear the buffer at any time with:
Delayed::Job.clear_buffer!
Or simply wrap your transaction with batch_delay_jobs
Delayed::Job.batch_delay_jobs do
.
.
.
end
# => Sends generated SQS messages in batch, then stops buffering.
rake jobs:work
If you want to process a specific queue that's not in your initializer or called default
, use the QUEUE
or QUEUES
environment variable:
QUEUE=tracking rake jobs:work
That will start pulling jobs off the default queue and processing them. The gem will also handle multiple named queues if you have configured rake
or scripts/delayed_job
accordingly however be sure to name the queue when putting objects on the queue:
user = User.new
user.delay(queue: 'bestest_queue').background_stuff