redlock 2.0.2 → 2.0.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/ci.yml +1 -1
- data/README.md +17 -2
- data/lib/redlock/client.rb +36 -6
- data/lib/redlock/version.rb +1 -1
- data/redlock.gemspec +1 -1
- data/spec/client_spec.rb +10 -0
- metadata +14 -8
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: a0dee2cedbef9dc37a61a0708dc788287d3ab70b96bfd2561267ddd580e128f9
|
4
|
+
data.tar.gz: 7e6292d1b22149c3c538c7f3bbd0285a9a7c51ef472d2ec22e99190927da5967
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 4fccf4ff8a3c5647e828a71b6b982b67f5bc1cc702a88279752ce53fc88addc4f5ffaa657f4c7f5f5ca09bfb9ee27f2aee8f7551a9bfa655f176d99c98d76051
|
7
|
+
data.tar.gz: ef9d3a5f10ec4b62b41ee890a69eb91ff16d92832ca75d82fb1387145330f979d8d01b614bf0893ad29669056f479a44f64278effcdbcc74150be2a4a2258f3d
|
data/.github/workflows/ci.yml
CHANGED
data/README.md
CHANGED
@@ -176,14 +176,29 @@ lock_manager.get_remaining_ttl_for_resource(resource)
|
|
176
176
|
|
177
177
|
## Redis client configuration
|
178
178
|
|
179
|
-
`Redlock::Client` expects URLs or Redis objects on initialization. Redis objects should be used for configuring the connection in more detail, i.e. setting username and password.
|
179
|
+
`Redlock::Client` expects URLs, or configurations or Redis objects on initialization. Redis objects should be used for configuring the connection in more detail, i.e. setting username and password.
|
180
180
|
|
181
181
|
```ruby
|
182
182
|
servers = [ 'redis://localhost:6379', RedisClient.new(:url => 'redis://someotherhost:6379') ]
|
183
183
|
redlock = Redlock::Client.new(servers)
|
184
184
|
```
|
185
185
|
|
186
|
-
|
186
|
+
To utilize `Redlock::Client` with sentinels you can pass an instance of `RedisClient` or just a configuration hash as part of the servers array during initialization.
|
187
|
+
|
188
|
+
```ruby
|
189
|
+
config = {
|
190
|
+
name: "mymaster",
|
191
|
+
sentinels: [
|
192
|
+
{ host: "127.0.0.1", port: 26380 },
|
193
|
+
{ host: "127.0.0.1", port: 26381 },
|
194
|
+
],
|
195
|
+
role: :master
|
196
|
+
}
|
197
|
+
client = RedisClient.sentinel(**config).new_client
|
198
|
+
servers = [ config, client ]
|
199
|
+
redlock = Redlock::Client.new(servers)
|
200
|
+
```
|
201
|
+
Redlock supports the same configuration hash as `RedisClient`.
|
187
202
|
|
188
203
|
## Redlock configuration
|
189
204
|
|
data/lib/redlock/client.rb
CHANGED
@@ -1,10 +1,11 @@
|
|
1
|
+
require 'monitor'
|
1
2
|
require 'redis-client'
|
2
3
|
require 'securerandom'
|
3
4
|
|
4
5
|
module Redlock
|
5
6
|
include Scripts
|
6
7
|
|
7
|
-
class LockAcquisitionError <
|
8
|
+
class LockAcquisitionError < LockError
|
8
9
|
attr_reader :errors
|
9
10
|
|
10
11
|
def initialize(message, errors)
|
@@ -163,21 +164,50 @@ module Redlock
|
|
163
164
|
end
|
164
165
|
|
165
166
|
def initialize(connection)
|
167
|
+
@monitor = Monitor.new
|
168
|
+
|
166
169
|
if connection.respond_to?(:with)
|
167
170
|
@redis = connection
|
168
171
|
else
|
169
172
|
if connection.respond_to?(:client)
|
170
173
|
@redis = connection
|
171
174
|
else
|
172
|
-
@redis =
|
175
|
+
@redis = initialize_client(connection)
|
173
176
|
end
|
174
177
|
@redis.extend(ConnectionPoolLike)
|
175
178
|
end
|
176
179
|
end
|
177
180
|
|
181
|
+
def initialize_client(options)
|
182
|
+
if options.key?(:sentinels)
|
183
|
+
if url = options.delete(:url)
|
184
|
+
uri = URI.parse(url)
|
185
|
+
if !options.key?(:name) && uri.host
|
186
|
+
options[:name] = uri.host
|
187
|
+
end
|
188
|
+
|
189
|
+
if !options.key?(:password) && uri.password && !uri.password.empty?
|
190
|
+
options[:password] = uri.password
|
191
|
+
end
|
192
|
+
|
193
|
+
if !options.key?(:username) && uri.user && !uri.user.empty?
|
194
|
+
options[:username] = uri.user
|
195
|
+
end
|
196
|
+
end
|
197
|
+
|
198
|
+
RedisClient.sentinel(**options).new_client
|
199
|
+
else
|
200
|
+
RedisClient.config(**options).new_client
|
201
|
+
end
|
202
|
+
end
|
203
|
+
|
204
|
+
def synchronize
|
205
|
+
@monitor.synchronize { @redis.with { |connection| yield(connection) } }
|
206
|
+
end
|
207
|
+
|
178
208
|
def lock(resource, val, ttl, allow_new_lock)
|
179
209
|
recover_from_script_flush do
|
180
|
-
|
210
|
+
synchronize { |conn|
|
181
211
|
conn.call('EVALSHA', Scripts::LOCK_SCRIPT_SHA, 1, resource, val, ttl, allow_new_lock)
|
182
212
|
}
|
183
213
|
end
|
@@ -185,7 +215,7 @@ module Redlock
|
|
185
215
|
|
186
216
|
def unlock(resource, val)
|
187
217
|
recover_from_script_flush do
|
188
|
-
|
218
|
+
synchronize { |conn|
|
189
219
|
conn.call('EVALSHA', Scripts::UNLOCK_SCRIPT_SHA, 1, resource, val)
|
190
220
|
}
|
191
221
|
end
|
@@ -195,7 +225,7 @@ module Redlock
|
|
195
225
|
|
196
226
|
def get_remaining_ttl(resource)
|
197
227
|
recover_from_script_flush do
|
198
|
-
|
228
|
+
synchronize { |conn|
|
199
229
|
conn.call('EVALSHA', Scripts::PTTL_SCRIPT_SHA, 1, resource)
|
200
230
|
}
|
201
231
|
end
|
@@ -212,7 +242,7 @@ module Redlock
|
|
212
242
|
Scripts::PTTL_SCRIPT
|
213
243
|
]
|
214
244
|
|
215
|
-
|
245
|
+
synchronize do |connnection|
|
216
246
|
scripts.each do |script|
|
217
247
|
connnection.call('SCRIPT', 'LOAD', script)
|
218
248
|
end
|
data/lib/redlock/version.rb
CHANGED
data/redlock.gemspec
CHANGED
@@ -18,7 +18,7 @@ Gem::Specification.new do |spec|
|
|
18
18
|
spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
|
19
19
|
spec.require_paths = ['lib']
|
20
20
|
|
21
|
-
spec.add_dependency 'redis-client', '
|
21
|
+
spec.add_dependency 'redis-client', '>= 0.14.1', '< 1.0.0'
|
22
22
|
|
23
23
|
spec.add_development_dependency 'connection_pool', '~> 2.2'
|
24
24
|
spec.add_development_dependency 'coveralls', '~> 0.8'
|
data/spec/client_spec.rb
CHANGED
@@ -59,6 +59,16 @@ RSpec.describe Redlock::Client do
|
|
59
59
|
lock_manager.unlock(lock_info)
|
60
60
|
end
|
61
61
|
|
62
|
+
it 'accepts Configuration hashes' do
|
63
|
+
config = { url: "redis://#{redis1_host}:#{redis1_port}" }
|
64
|
+
_redlock = Redlock::Client.new([config])
|
65
|
+
|
66
|
+
lock_info = lock_manager.lock(resource_key, ttl)
|
67
|
+
expect(lock_info).to be_a(Hash)
|
68
|
+
expect(resource_key).to_not be_lockable(lock_manager, ttl)
|
69
|
+
lock_manager.unlock(lock_info)
|
70
|
+
end
|
71
|
+
|
62
72
|
it 'does not load scripts' do
|
63
73
|
redis_client.call('SCRIPT', 'FLUSH')
|
64
74
|
|
metadata
CHANGED
@@ -1,29 +1,35 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: redlock
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.0.
|
4
|
+
version: 2.0.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Leandro Moreira
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-
|
11
|
+
date: 2023-08-20 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: redis-client
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
|
-
- - "
|
17
|
+
- - ">="
|
18
18
|
- !ruby/object:Gem::Version
|
19
19
|
version: 0.14.1
|
20
|
+
- - "<"
|
21
|
+
- !ruby/object:Gem::Version
|
22
|
+
version: 1.0.0
|
20
23
|
type: :runtime
|
21
24
|
prerelease: false
|
22
25
|
version_requirements: !ruby/object:Gem::Requirement
|
23
26
|
requirements:
|
24
|
-
- - "
|
27
|
+
- - ">="
|
25
28
|
- !ruby/object:Gem::Version
|
26
29
|
version: 0.14.1
|
30
|
+
- - "<"
|
31
|
+
- !ruby/object:Gem::Version
|
32
|
+
version: 1.0.0
|
27
33
|
- !ruby/object:Gem::Dependency
|
28
34
|
name: connection_pool
|
29
35
|
requirement: !ruby/object:Gem::Requirement
|
@@ -144,7 +150,7 @@ homepage: https://github.com/leandromoreira/redlock-rb
|
|
144
150
|
licenses:
|
145
151
|
- BSD-2-Clause
|
146
152
|
metadata: {}
|
147
|
-
post_install_message:
|
153
|
+
post_install_message:
|
148
154
|
rdoc_options: []
|
149
155
|
require_paths:
|
150
156
|
- lib
|
@@ -159,8 +165,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
159
165
|
- !ruby/object:Gem::Version
|
160
166
|
version: '0'
|
161
167
|
requirements: []
|
162
|
-
rubygems_version: 3.
|
163
|
-
signing_key:
|
168
|
+
rubygems_version: 3.4.10
|
169
|
+
signing_key:
|
164
170
|
specification_version: 4
|
165
171
|
summary: Distributed lock using Redis written in Ruby.
|
166
172
|
test_files:
|