Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/donatorsky/go-rate-limiter

A Go's rate limiting package for asynchronous jobs.
https://github.com/donatorsky/go-rate-limiter

async asynchronous go golang rate-limiter rate-limiting

Last synced: 2 months ago
JSON representation

A Go's rate limiting package for asynchronous jobs.

Awesome Lists containing this project

README

        

# Go Rate Limiter

A Go's rate limiting package for asynchronous jobs.

[![GitHub license](https://img.shields.io/github/license/donatorsky/go-rate-limiter)](https://github.com/donatorsky/go-rate-limiter/blob/main/LICENSE)
[![Build](https://github.com/donatorsky/go-rate-limiter/workflows/Tests/badge.svg?branch=main)](https://github.com/donatorsky/go-rate-limiter/actions?query=branch%3Amain)
[![codecov](https://codecov.io/gh/donatorsky/go-rate-limiter/branch/main/graph/badge.svg?token=A8WGM5K8DD)](https://codecov.io/gh/donatorsky/go-rate-limiter)

## What it does?

It allows for the execution of up to `n` jobs in `t` time. If not all jobs were completed in current `t`, during the next `t` period it will try to execute `n - unfinished jobs` jobs.

You can add as many jobs as You want. All jobs that exceed `n` limit will be queued and will run automatically, as soon as there is space for them.

## Installation

Install it using a package manager:

```shell
go get github.com/donatorsky/go-rate-limiter
```

And then use it in Your code:

```go
import "github.com/donatorsky/go-rate-limiter"
```

## Example usage

```go
// Execute up to 5 requests per 2 seconds
worker := ratelimiter.NewRateLimiter(time.Second*2, 5)

// Start jobs worker
worker.Begin()

// Stop jobs worker
defer worker.Finish()

// Queue and execute jobs
wg := sync.WaitGroup{}

log.Println("Start requesting")

for i := 0; i < 12; i++ {
wg.Add(1)

currentRequestId := i

worker.
Do(func() (interface{}, error) {
log.Printf("-> Request #%d has been started\n", currentRequestId)

// ...Your job execution definition...

// Return job result or error
return currentRequestId, nil
}).
Then(func(value interface{}) (result interface{}, err error) {
// In case Do() returned nil error
log.Printf("<- Request #%d: Then: %v\n", currentRequestId, v)

return nil, nil
}).
Catch(func(reason error) {
// In case Do() or Then() returned non-nil error
log.Printf("<- Request #%d: Catch: %v\n", currentRequestId, reason)
}).
Finally(func() {
// Always
//log.Printf("<- Request #%d: Finally: %v\n", currentRequestId, v)

wg.Done()
})
}

log.Println("Stop requesting")

wg.Wait()

log.Println("Processing finished")
```