rapidity 0.0.4.64534 → 0.0.4.88264
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Gemfile.lock +2 -2
- data/README.md +92 -0
- metadata +3 -2
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: b1ce2b9094e761e73932f6a5c4e249a54ab971fc89ee735b04c7748c68d562af
|
|
4
|
+
data.tar.gz: b33de26c3a4c10d18b087ba4ac168a9136764429b2a988be2814a591c7b82c5a
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 4cc96ac7a6f910293ff9d1ca0218894a04605253fb41caa627dea3593850b4e4b1bb6d9bd892733353cdcde73a23f151c08aa0b55e473a8e5533497c23876ca9
|
|
7
|
+
data.tar.gz: 79db7352433e17fce63344856da58107b0fd87215b1d5f5e1207ff250cb2a73e8d8f5afb8287b13f7538269ec3df061dc783f632eeb98fa6b964ae485822a6eb
|
data/Gemfile.lock
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
PATH
|
|
2
2
|
remote: .
|
|
3
3
|
specs:
|
|
4
|
-
rapidity (0.0.4.
|
|
4
|
+
rapidity (0.0.4.88264)
|
|
5
5
|
activesupport
|
|
6
6
|
connection_pool
|
|
7
7
|
redis
|
|
@@ -58,7 +58,7 @@ GEM
|
|
|
58
58
|
psych (3.3.2)
|
|
59
59
|
public_suffix (4.0.6)
|
|
60
60
|
rainbow (3.0.0)
|
|
61
|
-
redis (4.
|
|
61
|
+
redis (4.7.0)
|
|
62
62
|
reek (6.0.4)
|
|
63
63
|
kwalify (~> 0.7.0)
|
|
64
64
|
parser (~> 3.0.0)
|
data/README.md
ADDED
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
# Rapidity
|
|
2
|
+
|
|
3
|
+
[](https://rubygems.org/gems/rapidity)
|
|
4
|
+
[](https://rubygems.org/gems/rapidity/versions)
|
|
5
|
+
[](http://www.rubydoc.info/gems/rapidity)
|
|
6
|
+
|
|
7
|
+
[](https://lysander.rnds.pro/api/v1/badges/rapidity_coverage.html)
|
|
8
|
+
[](https://lysander.rnds.pro/api/v1/badges/rapidity_quality.html)
|
|
9
|
+
[](https://lysander.rnds.pro/api/v1/badges/rapidity_outdated.html)
|
|
10
|
+
[](https://lysander.rnds.pro/api/v1/badges/rapidity_vulnerable.html)
|
|
11
|
+
|
|
12
|
+
Simple but fast Redis-backed distributed rate limiter. Allows you to specify time interval and count within to limit distributed operations.
|
|
13
|
+
|
|
14
|
+
Features:
|
|
15
|
+
|
|
16
|
+
- extremly simple
|
|
17
|
+
- safe
|
|
18
|
+
- fast
|
|
19
|
+
|
|
20
|
+
## Usage
|
|
21
|
+
|
|
22
|
+
Rapidity has two variants:
|
|
23
|
+
|
|
24
|
+
- simple `Rapidity::Limiter` to handle single distibuted counter
|
|
25
|
+
- complex `Rapidity::Composer` to handle multiple counters at once
|
|
26
|
+
|
|
27
|
+
### Single conter with concurrent access
|
|
28
|
+
|
|
29
|
+
```ruby
|
|
30
|
+
pool = ConnectionPool.new(size: 10) do
|
|
31
|
+
Redis.new(url: ENV.fetch('REDIS_URL', 'redis://127.0.0.1:6379'))
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
# allow no more 10 requests within 5 seconds
|
|
35
|
+
limiter = Rapidity::Limiter.new(pool, name: 'requests', threshold: 10, interval: 5)
|
|
36
|
+
|
|
37
|
+
loop do
|
|
38
|
+
# try to obtain 3 requests at once
|
|
39
|
+
quota = limiter.obtain(3).times do
|
|
40
|
+
make_request
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
if quota == 0
|
|
44
|
+
# no more requests allowed within interval
|
|
45
|
+
sleep 1
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
### Multiple counters
|
|
52
|
+
|
|
53
|
+
```ruby
|
|
54
|
+
pool = ConnectionPool.new(size: 10) do
|
|
55
|
+
Redis.new(url: ENV.fetch('REDIS_URL', 'redis://127.0.0.1:6379'))
|
|
56
|
+
end
|
|
57
|
+
|
|
58
|
+
LIMITS = [
|
|
59
|
+
{ interval: 1, threshold: 2 }, # no more 2 requests per second
|
|
60
|
+
{ interval: 60, threshold: 200 }, # no more 200 requests per minute
|
|
61
|
+
{ interval: 86400, threshold: 10000 } # no more 10k requests per day
|
|
62
|
+
]
|
|
63
|
+
|
|
64
|
+
limiter = Rapidity::Composer.new(pool, name: 'requests', limits: LIMITS)
|
|
65
|
+
|
|
66
|
+
loop do
|
|
67
|
+
# try to obtain 3 requests at once
|
|
68
|
+
quota = limiter.obtain(3).times do
|
|
69
|
+
make_request
|
|
70
|
+
end
|
|
71
|
+
|
|
72
|
+
if quota == 0
|
|
73
|
+
# no more requests allowed within interval
|
|
74
|
+
puts limiter.remains # inspect current limits
|
|
75
|
+
sleep 1
|
|
76
|
+
end
|
|
77
|
+
end
|
|
78
|
+
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
## Installation
|
|
82
|
+
|
|
83
|
+
It's a gem:
|
|
84
|
+
```bash
|
|
85
|
+
gem install rapidity
|
|
86
|
+
```
|
|
87
|
+
There's also the wonders of [the Gemfile](http://bundler.io):
|
|
88
|
+
```ruby
|
|
89
|
+
gem 'rapidity'
|
|
90
|
+
```
|
|
91
|
+
|
|
92
|
+
|
metadata
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: rapidity
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 0.0.4.
|
|
4
|
+
version: 0.0.4.88264
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Yurusov Vlad
|
|
@@ -9,7 +9,7 @@ authors:
|
|
|
9
9
|
autorequire:
|
|
10
10
|
bindir: bin
|
|
11
11
|
cert_chain: []
|
|
12
|
-
date:
|
|
12
|
+
date: 2022-06-25 00:00:00.000000000 Z
|
|
13
13
|
dependencies:
|
|
14
14
|
- !ruby/object:Gem::Dependency
|
|
15
15
|
name: activesupport
|
|
@@ -232,6 +232,7 @@ files:
|
|
|
232
232
|
- Gemfile
|
|
233
233
|
- Gemfile.lock
|
|
234
234
|
- LICENSE
|
|
235
|
+
- README.md
|
|
235
236
|
- lib/rapidity.rb
|
|
236
237
|
- lib/rapidity/composer.rb
|
|
237
238
|
- lib/rapidity/limiter.rb
|