redis_failover 1.0.0 → 1.0.1
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.
- data/Changes.md +5 -0
- data/README.md +1 -1
- data/lib/redis_failover.rb +1 -1
- data/lib/redis_failover/node_manager.rb +7 -2
- data/lib/redis_failover/version.rb +1 -1
- data/misc/redis_failover.png +0 -0
- data/redis_failover.gemspec +1 -1
- metadata +6 -6
data/Changes.md
CHANGED
@@ -1,3 +1,8 @@
|
|
1
|
+
1.0.1
|
2
|
+
-----------
|
3
|
+
- Bumped required dependency on ZK gem. ZK 1.7.4 fixes a critical bug with locking (see https://github.com/slyphon/zk/issues/54)
|
4
|
+
- Fix an issue where a failover would not occur if we couldn't check the role of a downed master
|
5
|
+
|
1
6
|
1.0.0
|
2
7
|
-----------
|
3
8
|
** NOTE: This version of redis_failover requires that you upgrade your clients and Node Managers at the same time.
|
data/README.md
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
[](http://travis-ci.org/ryanlecompte/redis_failover)
|
4
4
|
|
5
|
-
redis_failover
|
5
|
+
redis_failover provides a full automatic master/slave failover solution for Ruby. Redis does not currently provide
|
6
6
|
an automatic failover capability when configured for master/slave replication. When the master node dies,
|
7
7
|
a new master must be manually brought online and assigned as the slave's new master. This manual
|
8
8
|
switch-over is not desirable in high traffic sites where Redis is a critical part of the overall
|
data/lib/redis_failover.rb
CHANGED
@@ -17,9 +17,9 @@ require 'redis_failover/errors'
|
|
17
17
|
require 'redis_failover/client'
|
18
18
|
require 'redis_failover/runner'
|
19
19
|
require 'redis_failover/version'
|
20
|
-
require 'redis_failover/node_strategy'
|
21
20
|
require 'redis_failover/node_manager'
|
22
21
|
require 'redis_failover/node_watcher'
|
22
|
+
require 'redis_failover/node_strategy'
|
23
23
|
require 'redis_failover/node_snapshot'
|
24
24
|
require 'redis_failover/manual_failover'
|
25
25
|
require 'redis_failover/failover_strategy'
|
@@ -259,9 +259,14 @@ module RedisFailover
|
|
259
259
|
# Check for case where a node previously thought to be the master was
|
260
260
|
# somehow manually reconfigured to be a slave outside of the node manager's
|
261
261
|
# control.
|
262
|
-
|
263
|
-
|
262
|
+
begin
|
263
|
+
if master && master.slave?
|
264
|
+
raise InvalidNodeRoleError.new(master, :master, :slave)
|
265
|
+
end
|
266
|
+
rescue RedisFailover::NodeUnavailableError => ex
|
267
|
+
logger.warn("Failed to check whether existing master has invalid role: #{ex.inspect}")
|
264
268
|
end
|
269
|
+
|
265
270
|
master
|
266
271
|
end
|
267
272
|
rescue ZK::Exceptions::NoNode
|
data/misc/redis_failover.png
CHANGED
Binary file
|
data/redis_failover.gemspec
CHANGED
@@ -18,7 +18,7 @@ Gem::Specification.new do |gem|
|
|
18
18
|
gem.add_dependency('redis', ['>= 2.2', '< 4'])
|
19
19
|
gem.add_dependency('redis-namespace')
|
20
20
|
gem.add_dependency('multi_json', '~> 1')
|
21
|
-
gem.add_dependency('zk', ['>= 1.7.
|
21
|
+
gem.add_dependency('zk', ['>= 1.7.4', '< 1.8'])
|
22
22
|
|
23
23
|
gem.add_development_dependency('rake')
|
24
24
|
gem.add_development_dependency('rspec')
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: redis_failover
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.
|
4
|
+
version: 1.0.1
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2012-
|
12
|
+
date: 2012-11-14 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: redis
|
@@ -72,7 +72,7 @@ dependencies:
|
|
72
72
|
requirements:
|
73
73
|
- - ! '>='
|
74
74
|
- !ruby/object:Gem::Version
|
75
|
-
version: 1.7.
|
75
|
+
version: 1.7.4
|
76
76
|
- - <
|
77
77
|
- !ruby/object:Gem::Version
|
78
78
|
version: '1.8'
|
@@ -83,7 +83,7 @@ dependencies:
|
|
83
83
|
requirements:
|
84
84
|
- - ! '>='
|
85
85
|
- !ruby/object:Gem::Version
|
86
|
-
version: 1.7.
|
86
|
+
version: 1.7.4
|
87
87
|
- - <
|
88
88
|
- !ruby/object:Gem::Version
|
89
89
|
version: '1.8'
|
@@ -209,7 +209,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
209
209
|
version: '0'
|
210
210
|
segments:
|
211
211
|
- 0
|
212
|
-
hash:
|
212
|
+
hash: -1642431998489370945
|
213
213
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
214
214
|
none: false
|
215
215
|
requirements:
|
@@ -218,7 +218,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
218
218
|
version: '0'
|
219
219
|
segments:
|
220
220
|
- 0
|
221
|
-
hash:
|
221
|
+
hash: -1642431998489370945
|
222
222
|
requirements: []
|
223
223
|
rubyforge_project:
|
224
224
|
rubygems_version: 1.8.23
|