Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/railsmechanic/sidewalk
Sidewalk is an Elixir client which is compatible with Sidekiq, the »simple, efficient background processing library for Ruby«.
https://github.com/railsmechanic/sidewalk
elixir message-queue queue ruby sidekiq
Last synced: about 1 month ago
JSON representation
Sidewalk is an Elixir client which is compatible with Sidekiq, the »simple, efficient background processing library for Ruby«.
- Host: GitHub
- URL: https://github.com/railsmechanic/sidewalk
- Owner: railsmechanic
- License: mit
- Created: 2016-07-23T13:21:50.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2018-10-09T06:46:32.000Z (over 6 years ago)
- Last Synced: 2024-11-07T23:49:40.280Z (2 months ago)
- Topics: elixir, message-queue, queue, ruby, sidekiq
- Language: Elixir
- Homepage: https://hex.pm/packages/sidewalk
- Size: 676 KB
- Stars: 8
- Watchers: 3
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Sidewalk [![Build Status](https://travis-ci.org/railsmechanic/sidewalk.svg?branch=master)](https://travis-ci.org/railsmechanic/sidewalk)
Sidewalk is an Elixir client which is compatible with Sidekiq, the »simple, efficient background processing library for Ruby«.
It can be used to enqueue jobs for later processing alongside e.g. with an already existing Ruby application.
For more information about Sidekiq please refer to http://sidekiq.org.To use Sidewalk you need to create a `%Sidewalk.Job{}` and enqueue it with one of the enqueue functions.
## Supported features
* Redis namespaces as already known with Sidekiq
* Ability to configure the Redis server and connection details
* Enqueuing jobs to be executed immediately
* Enqueuing jobs to be executed in X seconds
* Enqueuing jobs to be executed at a specific time## Installation
1. Add `sidewalk` to your list of dependencies in `mix.exs`:```elixir
def deps do
[{:sidewalk, "~> 0.4.0"}]
end
```2. Ensure `sidewalk` is started before your application:
```elixir
def application do
[applications: [:sidewalk]]
end
```3. Fetch dependencies
```bash
mix deps.get
```## Configuration
```elixir
config :sidewalk,
host: "localhost",
port: 6379,
password: "you password",
namespace: "your_namespace",
database: 0,
pool_size: 10
```You can also use environment variables:
```
config :sidewalk, host: {:system, "REDIS_HOST"}
```## Usage
Sidewalk offers three modes for enqueuing jobs:#### 1. Enqueuing a job with an immediate execution
```elixir
job = %Sidewalk.Job{class: "MyWorker", args: ['bob', 1, %{foo: 'bar'}]}
{:ok, jid} = Sidewalk.Client.enqueue(job) # => jid: "2f87a952ced00ea6cdd61245"
```#### 2. Enqueuing a job with a delayed execution defined in seconds
```elixir
# The time when the job should be executed is defined in secondsjob = %Sidewalk.Job{class: "MyWorker", args: ['bob', 1, %{foo: 'bar'}]}
{:ok, jid} = Sidewalk.Client.enqueue_in(job, 120) # => jid: "a805893e8bd98bf965d1dd54"
```#### 3. Enqueuing a job to be executed at a specific time
```elixir
# The time when the job should be executed is defined as a unix timestampjob = %Sidewalk.Job{class: "MyWorker", args: ['bob', 1, %{foo: 'bar'}]}
{:ok, jid} = Sidewalk.Client.enqueue_at(job, 1546293600) # => jid: "d6ceac7d6c42d35ff6cac8a0"
```## License
The MIT License (MIT). Please see [License File](https://github.com/railsmechanic/sidewalk/blob/master/LICENSE) for more information.