Skip to content

Job Schema

Grant Carthew edited this page Nov 18, 2016 · 14 revisions

Description

For reference purposes this document shows the schema of a job as it is saved in the RethinkDB database.

Below is a JSON representation of a job in the queue. This job contains valid data although it does not have any log entries.

Note: The example here is describing the job schema only, not your own data for job processing. You can populate your jobs with any properties you like. See the Tutorial document for more detail.

{
  dateCreated: 2016-09-19T03:07:44.394Z,
  dateEnable: 2016-09-19T03:12:44.451Z,
  dateFinished: 2016-09-19T03:07:44.469Z,
  dateStarted: 2016-09-19T03:07:44.451Z,
  id: '5127d082-fe7e-4e88-b1de-7093029695c3',
  log: []
  priority: 'normal',
  progress: 0,
  queueId: 'WebDev::rjqJobQueueTestJobs:1942:ebc89e54-f7d3-40a1-952a-3bb152d154ce',
  retryCount: 0,
  retryDelay: 600000,
  retryMax: 3,
  status: 'completed',
  timeout: 300000
}

Following is a breakdown of all of the job properties and a brief description of what they are used for. Click on the document links inline for more detail.

Why is this Important?

Although rethinkdb-job-queue supports a search feature by calling Queue.findJob, you can use the job schema above and the RethinkDB driver to build your own search functionality. Apart from searching you could augment the jobs in the database any way you like.

The RethinkDB driver is available to you by calling Queue.r. Once you have that you can use the RethinkDB API and the rethinkdbdash API to interact with the job documents in the database.

As an example of how flexible this can be, you could search the database for jobs that have been completed and change the properties of the jobs to rerun them.

Please refer to the RethinkDB and rethinkdbdash documentation for more detail.

Main

How It Works

Contributing

API

Queue Methods

Queue Properties

Queue Events

Job Methods

Job Properties

Documentation

Clone this wiki locally