rrq queue worker
rrq queue worker
Details
A rrq queue worker. These are not typically for interacting with but will sit and poll a queue for jobs.
Public fields
id
The id of the worker
config
The name of the configuration used by this worker
controller
An rrq controller object
Methods
Method new()
Constructor
Usage
rrq_worker$new(
queue_id,
name_config = "localhost",
worker_id = NULL,
timeout_config = 0,
is_child = FALSE,
con = redux::hiredis(),
offload_path = NULL
)
Arguments
queue_id
The queue id
name_config
Optional name of the configuration. The default "localhost" configuration always exists. Create new configurations using rrq_worker_config_save.
worker_id
Optional worker id. If omitted, a random id will be created.
timeout_config
How long to try and read the worker configuration for. Will attempt to read once a second and throw an error if config cannot be located after
timeout
seconds. Use this to create workers before their configurations are available. The default (0) is to assume that the configuration is immediately available.is_child
Logical, used to indicate that this is a child of the real worker. If
is_child
isTRUE
, then most other arguments here have no effect (e.g.,queue
all the timeout / idle / polling arguments) as they come from the parent. Not for general use.con
A redis connection
offload_path
The path to create an offload store at. See rrq_controller for details.
Method log()
Create a log entry. This will print a human readable format to screen and a machine-readable format to the redis database.
Method load_envir()
Load the worker environment by creating a new
environment object and running the create hook (if configured).
See rrq_worker_envir_set()
for details.
Method step()
Take a single "step". This consists of
Poll for work (
$poll()
)If work found, run it (either a task or a message)
If work not found, check the timeout
Method loop()
The main worker loop. Use this to set up the main worker event loop, which will continue until exiting (via a timeout or message).
Method format()
Create a nice string representation of the worker. Used automatically to print the worker by R6.
Method progress()
Submit a progress message. See
rrq_task_progress_update()
for details of this mechanism.
Arguments
value
An R object with the contents of the update. This will overwrite any previous progress value, and can be retrieved with rrq_task_progress. A value of
NULL
will appear to clear the status, asNULL
will also be returned if no status is found for a task.error
Logical, indicating if we should throw an error if not running as an
rrq
task. Set this toFALSE
if you want code to work without modification within and outside of anrrq
job, or toTRUE
if you want to be sure that progress messages have made it to the server.
Method task_eval()
Evaluate a task. When running a task on a separate
process, we will always set two environment variables:
* RRQ_WORKER_ID
this is the id field
* RRQ_TASK_ID
this is the task id