Sha256: d3ed97fe4ea9c578cd00be9a7562b0b94012532414de5f9dab749f460abc8567
Contents?: true
Size: 1.32 KB
Versions: 1
Compression:
Stored size: 1.32 KB
Contents
# frozen_string_literal: true require 'aws-sdk-sqs' require 'concurrent' module ActiveJob module QueueAdapters # == Async adapter for Amazon SQS ActiveJob # # This adapter queues jobs asynchronously (ie non-blocking). Error handler can be configured # with +Aws::Rails::SqsActiveJob.config.async_queue_error_handler+. # # To use this adapter, set up as: # # config.active_job.queue_adapter = :amazon_sqs_async class AmazonSqsAsyncAdapter < AmazonSqsAdapter private def _enqueue(job, body = nil, send_message_opts = {}) # FIFO jobs must be queued in order, so do not queue async queue_url = Aws::Rails::SqsActiveJob.config.queue_url_for(job.queue_name) if Aws::Rails::SqsActiveJob.fifo?(queue_url) super else # Serialize is called here because the job’s locale needs to be # determined in this thread and not in some other thread. body = job.serialize Concurrent::Promises .future { super } .rescue do |e| Rails.logger.error "Failed to queue job #{job}. Reason: #{e}" error_handler = Aws::Rails::SqsActiveJob.config.async_queue_error_handler error_handler&.call(e, job, send_message_opts) end end end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
aws-sdk-rails-3.13.0 | lib/active_job/queue_adapters/amazon_sqs_async_adapter.rb |