Sha256: ba74b7dcbfce47b9ba366d0f79bf18e9d51d8cb15c60529b08b6137ccad820d8
Contents?: true
Size: 1.42 KB
Versions: 3
Compression:
Stored size: 1.42 KB
Contents
# frozen_string_literal: true require 'aws-sdk-sqs' require 'concurrent' module ActiveJob module QueueAdapters # Asynchronous adapter for Amazon SQS ActiveJob This adapter queues jobs asynchronously (ie non-blocking). # # An error handler can be configured with: # # Aws::ActiveJob::SQS.config.async_queue_error_handler = ->(error, job, send_message_opts) { ... } # # To use this adapter, set up as: # # config.active_job.queue_adapter = :sqs_async class SqsAsyncAdapter < SqsAdapter private def _enqueue(job, body = nil, send_message_opts = {}) # FIFO jobs must be queued in order, so do not queue async queue_url = Aws::ActiveJob::SQS.config.queue_url_for(job.queue_name) if Aws::ActiveJob::SQS.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(job, body, send_message_opts) } .rescue do |e| # TODO: should be config logger? fails Rails.logger.error "Failed to queue job #{job}. Reason: #{e}" error_handler = Aws::ActiveJob::SQS.config.async_queue_error_handler error_handler&.call(e, job, send_message_opts) end end end end end end
Version data entries
3 entries across 3 versions & 1 rubygems