Oban v0.3.0 Oban.Worker behaviour View Source
Defines a behavior and macro to guide the creation of worker modules.
Worker modules do the work of processing a job. At a minimum they must define a perform/1
function, which will be called with an args
map.
Defining Workers
Define a worker to process jobs in the events
queue:
defmodule MyApp.Workers.Business do
use Oban.Worker, queue: "events", max_attempts: 10
@impl Oban.Worker
def perform(args) do
IO.inspect(args)
end
end
The perform/1
function will always receive the jobs args
map. In this example the worker
will simply inspect any arguments that are provided. Note that the return value isn't important.
If perform/1
returns without raising an exception the job is considered complete.
Enqueuing Jobs
All workers implement a new/2
function that converts an args map into a job changeset
suitable for inserting into the database for later execution:
%{in_the: "business", of_doing: "business"}
|> MyApp.Workers.Business.new()
|> MyApp.Repo.insert()
The worker's defaults may be overridden by passing options:
%{vote_for: "none of the above"}
|> MyApp.Workers.Business.new(queue: "special", max_attempts: 5)
|> MyApp.Repo.insert()
See Oban.Job
for all available options.
Link to this section Summary
Callbacks
Build a job changeset for this worker with optional overrides.
The perform/1
function is called when the job is executed.
Link to this section Callbacks
new(args, opts)
View Source
new(args :: Oban.Job.args(), opts :: [Oban.Job.option()]) :: Ecto.Changeset.t()
new(args :: Oban.Job.args(), opts :: [Oban.Job.option()]) :: Ecto.Changeset.t()
Build a job changeset for this worker with optional overrides.
See Oban.Job.new/2
for the available options.
perform(args) View Source
The perform/1
function is called when the job is executed.
The function is passed a job's args, which is always a map with string keys.
The return value is not important. If the function executes without raising an exception it is considered a success. If the job raises an exception it is a failure and the job may be scheduled for a retry.