Skip to content

Node.js/Typescript Background Task/Streaming Framework (Kafka, AWS SQS, Redis)

License

Notifications You must be signed in to change notification settings

ordermentum/steveo

Repository files navigation

Welcome to steveo 👋

Version License: Apache--2.0

npm version CI npm npm

Steveo is a comprehensive framework for handling background job processing in Node.js. It offers support for popular messaging systems such as Kafka, SQS, and Redis.

In Australian culture, it is common to abbreviate names, like "John" becoming "Johno," or add extra vowels, like "Sarah" becoming "Sazza." The name "Steveo" is a playful play on "Steve" inspired by Steve Jobs.

The primary purpose of Steveo is to handle asynchronous task processing. It allows you to define tasks that involve time-consuming operations without causing a blockage in the main execution flow of an HTTP request. Think of it as sidekiq for node.js with support for multiple backends.

Steveo also bundles a task scheduling framework for Postgresql as an optional addon.

Multiple tasks can be strung together to form workflows that will reliably handle errors and retry patterns.

Installation

This is a Node.js module available through the npm registry.

Before installing, download and install Node.js. Node.js 16 or higher is required.

If this is a brand new project, make sure to create a package.json first with the npm init command.

Installation is done using the npm install command:

$ npm install steveo

Author

👤 [email protected]

Example

(async () => {
  const steveo = Steveo();

  const example = steveo.task('example-task', async ({ name }) => {
    console.log(`hello ${name}`);
  });

  await example.publish({ name: 'tommo' });
  await example.publish({ name: 'bazza' });

  // or
  steve.publish('example-task', { name: 'tim' });

  await steveo.runner().process();
})();

Publish without registering a task

await steveo.publish('example-task', { name: 'Apple' });

For more details, see example

Contributing

Installing dependencies

yarn install

Running tests

yarn run test

Architecture

On a highlevel, it works as below, Steveo has 3 main components

You publish a message to a queue for a defined task or workflow.

Error Handling: Steveo provides mechanisms to handle errors during task processing. It emits events for task failures and connection failures, allowing you to implement appropriate error handling strategies.

Task

Holds the information about the type of task. It has below methods,

  • publish - send a message onto a queue
  • subscribe - process a message

Workflow

Allows a sequence of steps to be defined and executed.

The output of each step will be fed into the arguments of the proceeding step.

Registry

Task Registry: Steveo maintains a registry that keeps track of tasks + workflows and their associated handlers. When a new task is created, it is added to the registry for dispatch handling.

Responsible for keeping the inventory of tasks + workflows & event manager. Whenever a new task or workflow is created, an entry will be added in the registry

Consumer

Responsible for consuming messages,

  • process method initialize group consumers and start to consume the messages. It will then call the subscribe callback set on the task
              +-----------+     +-----------+     +-----------+
              |           |     |           |     |           |
PUBLISH ----->|   TASK    |     | REGISTRY  |     | CONSUMER  |-----> RECEIVE
              |           |     |           |     |           |
              |           |     |           |     |           |
              +-----------+     +-----------+     +-----------+

Events

Event Emission: Steveo emits various events during task processing, allowing you to handle different stages of task execution, such as receiving a message, completing a task, or encountering failures.

Emitting events based on success/failures

Event Description
runner_receive Received a message
runner_complete Completed running the associated task
runner_failure Failed running the associated task
runner_connection_failure Error while polling for message (Kafka only)
task_send
task_success
task_failure
task_added
task_removed
producer_success
producer_failure
pool_reserve When a consumer reserves a handle in the worker pool
pool_release When a consumer releases a handle from the worker pool

Packages

Package Description
steveo Core steveo package that provides the async task processing functionality
@steveojs/newrelic New Relic addon for Steveo to provide APM tracing
@steveojs/sentry Sentry addon to provide tracing and error tracking
@steveojs/statsd Statsd addon to provide metrics to a statsd server
@steveojs/prisma Job Scheduler using Prisma ORM
@steveojs/sequelize Job Scheduler using Sequelize ORM

Scheduler

This repo also contains two schedulers for scheduling tasks using postgresql (prisma and sequelize).

Needs a jobs table to be created. See packages/prisma/migrations or packages/sequelize/migrations in the individual packages

How?

See apps/example/bin/jobs and apps/src/index

For prisma, you will need take the prisma/prisma/schema.prisma add put it into your app prisma/schema.prisma file. Prisma has no way to share or import schemas from packages.