Skip to content

A middleware for go-workers trying to minimize the chance of running same job type multiple times in parallel

Notifications You must be signed in to change notification settings

PlanitarInc/go-workers-once

Repository files navigation

Build Status GoDoc

A middleware for go-workers trying to avoid running same job type in parallel.

IMPORTANT: the middleware does not work on top of vanilla jrallison/go-workers, but requires Planitar's fork PlanitarInc/go-workers. The fork adds a support for 2 additional functions: PrepareEnqueuMsg() and EnqueueMsg().

Usage

Enqueue your tasks with EnqueueOnce(), add a customized middleware to take care of these tasks.

Example

package main

import (
    "github.com/PlanitarInc/go-workers"
    "github.com/PlanitarInc/go-workers-once"
)

func main() {
  workers.Configure(map[string]string{
    // location of redis instance
    "server":  "localhost:6379",
    // instance of the database
    "database":  "0",
    // number of connections to keep open with redis
    "pool":    "30",
    // unique process id for this instance of workers (for proper recovery of inprogress jobs on crash)
    "process": "1",
  })

  workers.Middleware.Append(&once.Middleware{})
  workers.Process("myqueue", myJob, 20)

  // Enqueue jobs through once
  // The job of type `add-1-2` is added to the queue
  once.EnqueueOnce("myqueue", "add-1-2", []int{1, 2}, nil)
  // The job of type `add-1-2` is ignored
  once.EnqueueOnce("myqueue", "add-1-2", []int{1, 2}, nil)

  // Blocks until the enqueued job is done (either fails or succeeds)
  once.WaitForJobType("myqueue", "add-1-2")

  // Returns immediately since there are no jobs of type `add-1-2`
  // in the queue.
  once.WaitForJobType("myqueue", "add-1-2", WaitOptions{
    StopIfEmpty: true,
  })

  // Returns after 10 milliseconds since there are no jobs of type `add-1-2`
  // in the queue.
  once.WaitForJobType("myqueue", "add-1-2", WaitOptions{
    Timeout: 10 * time.Millisecond,
  })

  // Blocks until a job of type `add-1-2` is added to the queue.
  // In this example it will hang forever.
  once.WaitForJobType("myqueue", "add-1-2")
}

Develop

Test your changes, if you have Redis listening on localhost:

go test ./...

Test your changes, if you have a remote Redis:

REDIS_HOST=<REDIS_HOST> go test ./...

Release

go generate ./...
git add lua/script.go
git commit

About

A middleware for go-workers trying to minimize the chance of running same job type multiple times in parallel

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •