rerate is a redis-based ratecounter and ratelimiter
- Dead simple api
- With redis as backend, multiple rate counters/limiters can work as a cluster
- Count/Limit requests any period, 2 day, 1 hour, 5 minute or 2 second, it's up to you
- Recording requests as a histotram, which can be used to visualize or monitor
- Limit requests from single ip, userid, applicationid, or any other unique identifier
package main
import (
"github.com/abo/rerate"
)
...
func main() {
// redigo buckets
pool := newRedisPool("localhost:6379", "")
buckets := rerate.NewRedigoBuckets(pool)
// OR redis buckets
// client := redis.NewClient(&redis.Options{
// Addr: "localhost:6379",
// Password: "",
// DB: 0,
// })
// buckets := rerate.NewRedisBuckets(client)
// Counter
counter := rerate.NewCounter(buckets, "rl:test", 10 * time.Minute, 15 * time.Second)
counter.Inc("click")
c, err := counter.Count("click")
// Limiter
limiter := rerate.NewLimiter(buckets, "rl:test", 1 * time.Hour, 15 * time.Minute, 100)
limiter.Inc("114.255.86.200")
rem, err := limiter.Remaining("114.255.86.200")
exceed, err := limiter.Exceeded("114.255.86.200")
}
Install rerate using the "go get" command:
go get github.com/abo/rerate
cd cmd/sparkline
npm install webpack -g
npm install
webpack && go run main.go
Open http://localhost:8080
in Browser, And then move mouse.
WELCOME
rerate is available under the The MIT License (MIT).