Sha256: 9dd8545133608a6651e6e2a9ed1c8783707fa9bec5b09d914f2eefe9616a8fd0

Contents?: true

Size: 1.32 KB

Versions: 2

Compression:

Stored size: 1.32 KB

Contents

class CreateDelayedJobs < ActiveRecord::Migration[5.0]
  def self.up
    create_table :delayed_jobs, :force => true do |table|
      table.integer :priority, :default => 0, :null => false # Allows some jobs to jump to the front of the queue
      table.integer :attempts, :default => 0, :null => false # Provides for retries, but still fail eventually.
      table.text :handler, :null => false                    # YAML-encoded string of the object that will do work
      table.text :last_error                                 # reason for last failure (See Note below)
      table.datetime :run_at                                 # When to run. Could be Time.zone.now for immediately, or sometime in the future.
      table.datetime :locked_at                              # Set when a client is working on this object
      table.datetime :failed_at                              # Set when all retries have failed (actually, by default, the record is deleted instead)
      table.string :locked_by                                # Who is working on this object (if locked)
      table.string :queue                                    # The name of the queue this job is in
      table.timestamps
    end

    add_index :delayed_jobs, [:priority, :run_at], :name => 'delayed_jobs_priority'
  end

  def self.down
    drop_table :delayed_jobs
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
action_mailer_kafka-1.0.0 example/db/migrate/20141115060216_create_delayed_jobs.rb
action_mailer_kafka-0.1.0 example/db/migrate/20141115060216_create_delayed_jobs.rb