1.0.0 • Published 5 years ago

adonis-bqueue v1.0.0

Weekly downloads
6
License
MIT
Repository
github
Last release
5 years ago

Adonis Beequeue Provider

A Bee-Queue provider for the Adonis framework.

This library provides an easy way to get started with an asynchronous job queue for AdonisJS.

Install

npm install --save adonis-bqueue

Configure

Register the bqueue provider in start/app.js:

const providers = [
  ...
  'adonis-bqueue/providers/QueueProvider'
]

Register the commands provider in start/app.js:

const aceProviders = [
  ...
  'adonis-bqueue/providers/CommandsProvider'
]

Register the jobs in start/app.js:

const jobs = [
  ...
  'App/Queues/Example'
]

And then export the jobs array:

module.exports = { providers, aceProviders, aliases, commands, queues }

Add a configuration file in config/queue.js. For example:

'use strict'

module.exports = {
  connections: {
    default: {
      prefix: 'bq',
      stallInterval: 5000,
      nearTermWindow: 1200000,
      delayedDebounce: 1000,
      redis: {
        host: '127.0.0.1',
        port: 6379,
        db: 14,
        options: {}
      },
      isWorker: true,
      getEvents: true,
      sendEvents: true,
      storeJobs: true,
      ensureScripts: true,
      activateDelayedJobs: false,
      removeOnSuccess: true,
      removeOnFailure: false,
      redisScanCount: 100
    },
    custom: {
      prefix: 'bq',
      stallInterval: 5000,
      nearTermWindow: 1200000,
      delayedDebounce: 1000,
      redis: {
        host: '127.0.0.1',
        port: 6379,
        db: 15,
        options: {}
      },
      isWorker: true,
      getEvents: true,
      sendEvents: true,
      storeJobs: true,
      ensureScripts: true,
      activateDelayedJobs: false,
      removeOnSuccess: true,
      removeOnFailure: false,
      redisScanCount: 100
    }
  }
}

Usage

Command List

CommandDescription
adonis bqueue:listenStarting the listener
adonis make:queueMake a new Queue (Job)

Starting the listener

Starting an instance of the bqueue listener is easy with the included ace command. Simply run adonis bqueue:listen --connection=default.

Creating your first job

They expose the following properties:

NameRequiredTypeStaticDescription
keytruestringtrueA unique key for this job
handletruefunctionfalseA function that is called for this job.

Dispatching jobs

Now that your job listener is running and ready to do some asynchronous work, you can start dispatching jobs.

const Queue = use('Bqueue')
const Job = use('App/Queue/Example')
const connection = 'custom' // [option] If you not define this will be use `default`
const data = { test: 'data' } // Data to be passed to job handle
const job = Queue.dispatch(Job.key, data, { connection })

// If you want to wait on the result, you can do this
const result = await job.result

Thanks

Special thanks to the creator(s) of AdonisJS for creating such a great framework.