README.md 3.6 KB
Newer Older
1 2 3 4
# Active Job -- Make work happen later

Active Job is a framework for declaring jobs and making them run on a variety
of queueing backends. These jobs can be everything from regularly scheduled
5
clean-ups, to billing charges, to mailings. Anything that can be chopped up into
6 7
small units of work and run in parallel, really.

C
Cristian Bica 已提交
8
It also serves as the backend for ActionMailer's #deliver_later functionality
9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
that makes it easy to turn any mailing into a job for running later. That's
one of the most common jobs in a modern web application: Sending emails outside
of the request-response cycle, so the user doesn't have to wait on it.

The main point is to ensure that all Rails apps will have a job infrastructure
in place, even if it's in the form of an "immediate runner". We can then have
framework features and other gems build on top of that, without having to worry
about API differences between Delayed Job and Resque. Picking your queuing
backend becomes more of an operational concern, then. And you'll be able to
switch between them without having to rewrite your jobs.


## Usage

Set the queue adapter for Active Job:

``` ruby
ActiveJob::Base.queue_adapter = :inline # default queue adapter
```
28 29
Note: To learn how to use your preferred queueing backend see its adapter
documentation at ActiveJob::QueueAdapters.
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45

Declare a job like so:

```ruby
class MyJob < ActiveJob::Base
  queue_as :my_jobs

  def perform(record)
    record.do_work
  end
end
```

Enqueue a job like so:

```ruby
C
Cristian Bica 已提交
46
MyJob.perform_later record  # Enqueue a job to be performed as soon the queueing system is free.
47 48 49
```

```ruby
C
Cristian Bica 已提交
50
MyJob.set(wait_until: Date.tomorrow.noon).perform_later(record)  # Enqueue a job to be performed tomorrow at noon.
51 52 53
```

```ruby
C
Cristian Bica 已提交
54
MyJob.set(wait: 1.week).perform_later(record) # Enqueue a job to be performed 1 week from now.
55 56 57 58 59 60 61
```

That's it!


## GlobalID support

A
Abdelkader Boudih 已提交
62
Active Job supports [GlobalID serialization](https://github.com/rails/globalid/) for parameters. This makes it possible
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
to pass live Active Record objects to your job instead of class/id pairs, which
you then have to manually deserialize. Before, jobs would look like this:

```ruby
class TrashableCleanupJob
  def perform(trashable_class, trashable_id, depth)
    trashable = trashable_class.constantize.find(trashable_id)
    trashable.cleanup(depth)
  end
end
```

Now you can simply do:

```ruby
class TrashableCleanupJob
  def perform(trashable, depth)
    trashable.cleanup(depth)
  end
end
```

A
Abdelkader Boudih 已提交
85
This works with any class that mixes in GlobalID::Identification, which
86 87 88 89 90
by default has been mixed into Active Record classes.


## Supported queueing systems

91 92 93
Active Job has built-in adapters for multiple queueing backends (Sidekiq,
Resque, Delayed Job and others). To get an up-to-date list of the adapters
see the API Documentation for [ActiveJob::QueueAdapters](http://api.rubyonrails.org/classes/ActiveJob/QueueAdapters.html).
94 95 96 97 98

## Auxiliary gems

* [activejob-stats](https://github.com/seuros/activejob-stats)

C
Cristian Bica 已提交
99
## Download and installation
100

C
Cristian Bica 已提交
101
The latest version of Active Job can be installed with RubyGems:
102

C
Cristian Bica 已提交
103 104 105 106 107 108 109
```
  % [sudo] gem install activejob
```

Source code can be downloaded as part of the Rails project on GitHub

* https://github.com/rails/rails/tree/master/activejob
110 111 112

## License

C
Cristian Bica 已提交
113
ActiveJob is released under the MIT license:
114 115

* http://www.opensource.org/licenses/MIT
C
Cristian Bica 已提交
116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132


## Support

API documentation is at

* http://api.rubyonrails.org

Bug reports can be filed for the Ruby on Rails project here:

* https://github.com/rails/rails/issues

Feature requests should be discussed on the rails-core mailing list here:

* https://groups.google.com/forum/?fromgroups#!forum/rubyonrails-core