gordon

command module
v1.5.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 5, 2016 License: MIT Imports: 11 Imported by: 0

README

Gordon

Gordon aims to be a provide a simple, reliable and lightweight task-queue.

It is built utilizing Go and Redis.

Gordon provides functionality to execute tasks in the background of your main application/api/service. By using Go-routines, a concurrent execution of tasks can easily be achieved. As Gordon just executes commands, you can use any kind of script or application, as long as it runs on the command-line.

Getting Started

  1. Build

# get/update the code
go get -u github.com/nevsnode/gordon

# build the binary
go build github.com/nevsnode/gordon

Then create a configuration file. You'll probably just want to copy the example file and name it gordon.config.toml. Change the fields in the file accordingly and deploy it in the same directory as the generated binary.

  1. Run

Now you can start the Gordon application. It accepts the following flags (all are optional):

Flag Type Description
c string Path to the configuration file (Overrides the default ./gordon.config.toml)
t bool Test configuration
V bool Show version
v bool Enable verbose/debugging output

Example:

./gordon -c /path/to/gordon.config.toml -v
  1. Integrate

The last step is to integrate Gordon so that commands can be executed.

This is achieved by inserting entries into Redis-lists. Take a look at the section Handling Tasks for a brief explanation.

Handling Tasks

Creating Tasks

Gordon essentially works by checking for entries in specific Redis-lists.

The lists are named by this scheme:

$queue_key:$task_type

Assuming your queue_key is myqueue, and a task is configured with the type update_something, the list would be named this:

myqueue:update_something

By knowing the list-name, you are now able to trigger the execution of this task. You only need to push a task-entry into this Redis-list by using RPUSH. The command in Redis would then look like this:

RPUSH myqueue:update_something '{"args":["1234"]}'

This will initiate the execution of the configured Script for the task update_something with the first parameter beeing 1234.

Assuming your task is configured with script /path/to/do_something.sh, Gordon will execute this:

/path/to/do_something.sh 1234

Structure of a task entry

The values that are inserted to the Redis-lists have to be JSON-encoded strings, with this structure:

{
    "args": [
        "param1",
        "param2"
    ]
}

They have to be an object with the property args that is an array containing strings. When no parameters are needed, just pass an empty array.

Arguments that are contained in args, will be passed to the script in the exact same order. The task above would therefor be executed like this:

/path/to/do_something.sh "param1" "param2"

Failed Tasks

Tasks returning an exit-code other than 0 or creating output are considered to be failed. In some cases one might want to handle these tasks separately, for instance re-queuing them.

An error_script, if defined, can be executed to notify about failed tasks. But in some cases it is useful to handle them programmatically (in addition to notifying, or instead).

It is therefor possible to enable saving of failed tasks to separate Redis-lists. To enable this functionality failed_tasks_ttl must be set and have a value greater than 0.

Note: The time-to-live value applies to the whole list, not just single entries!

These lists are named after this scheme:

$queue_key:$task_type:failed

For example:

myqueue:update_something:failed

The values in this list are the same as the normal task entries, but also include a string-property error_message, like this:

{
    "args": [
        "param1",
        "param2"
    ],
    "error_message": "Some error happened!"
}

You may then use LINDEX or LPOP to retrieve failed tasks from Redis and handle them.

Libraries

As Gordon just reads and inserts to Redis, you can also just use the commonly used libraries for your programming language.

Development

Updating the vendored libraries:

git subtree pull --squash --prefix=vendor/github.com/mediocregopher/radix.v2 https://github.com/mediocregopher/radix.v2 master
git subtree pull --squash --prefix=vendor/github.com/BurntSushi/toml https://github.com/BurntSushi/toml master
git subtree pull --squash --prefix=vendor/github.com/jpillora/backoff https://github.com/jpillora/backoff master

Credits

Kudos to the following libraries which are used by gordon:

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
Package config provides functionality to read and parse the Gordon configuration file.
Package config provides functionality to read and parse the Gordon configuration file.
Package output handles the output for Gordon.
Package output handles the output for Gordon.
Package stats provides functionality for basic usage statistics in Gordon.
Package stats provides functionality for basic usage statistics in Gordon.
Package taskqueue provides the functionality for receiving, handling and executing tasks.
Package taskqueue provides the functionality for receiving, handling and executing tasks.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL